Lock 锁重点(Juc-02)

本贴最后更新于 1461 天前,其中的信息可能已经时移世改

Lock 接口

image.png

image.png

image.png

**公平锁:**十分的公平,可以先来后到

**非公平锁:**十分不公平,可以插队 (默认)

public class SaleTicketDemo02 {
    public static void main(String[] args) {
        Ticket2 ticket = new Ticket2();
        new Thread(()->{for (int i = 0; i <60 ; i++) ticket.sale(); },"A").start();
        new Thread(()->{for (int i = 0; i <60 ; i++) ticket.sale(); },"B").start();
        new Thread(()->{for (int i = 0; i <60 ; i++) ticket.sale(); },"C").start();
    }
}
/*
* 1、new ReentrantLock()
* 2.lock.lock() 加锁
* 3、 finally=>lock.unlock() 解锁
* */
//资源类OOP
class Ticket2 {
    private int number = 50;
    Lock lock = new ReentrantLock();
    public void sale() {
        lock.lock();
        try {
            if(number>0){
                System.out.println(Thread.currentThread().getName()+"买到了第:"+number-- +"票");
            }
        }catch (Exception e){
        }finally {
            lock.unlock();
        }
    }
}

Synchronized 和 Lock 区别

  • synchronized 内置的 java 的关键子,Lock 是一个 Java 类
  • synchronized 无法判断获取所得状态,Lock 可以判断是否获取到了锁
  • synchronized 会自动释放锁,lock 必须要手动释放锁!如果不释放锁那么就是个死锁
  • synchronized 线程 1(获得锁,阻塞)、线程 2(等待,傻乎乎的等着),Lock 锁就不一定会等下去
  • synchronized 可重入锁,不可以中断,非公平的;Lock,可重入锁 ,可以判断锁,非公平的锁,可以自己设置
  • synchronized 适合锁少量的代码同步问题,Lock 适合锁大量的 同步代码!

生产者和消费者问题 synchronized 版

进行线程之间的通信

下面是两个线程之间的通信

解决方案

if 换成 while,类似下面这样

JUC 版本的生产者和消费者问题

image.png

代码实现

Condition 进准的通知和和唤醒线程

A、B、C、D 有序执行

代码测试

8 锁现象

如何判断锁的是谁,锁的到底是谁

new this 锁的是具体的一个手机

static Class 唯一的一个模板

  • JUC
    17 引用 • 3 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...