Lock 接口
**公平锁:**十分的公平,可以先来后到
**非公平锁:**十分不公平,可以插队 (默认)
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 版本的生产者和消费者问题
代码实现
Condition 进准的通知和和唤醒线程
A、B、C、D 有序执行
代码测试
8 锁现象
如何判断锁的是谁,锁的到底是谁
new this 锁的是具体的一个手机
static Class 唯一的一个模板
欢迎来到这里!
我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。
注册 关于