Lock锁
经典卖票例子
传统Synchronized来实现。
package com.cc.demo1;
/**
* 真正的多线程开发,公司中的开发,降低耦合性
* 线程就是一个单独的资源类,没有任何附属的操作!
* 1、 属性、方法
*/
public class SaleTicketDemo1 {
public static void main(String[] args) {
// 并发:多线程操作同一个资源类, 把资源类丢入线程
Ticket ticket = new Ticket();
new Thread(()->{
for (int i = 1; i < 40 ; i++) {
ticket.sale();
}
},"A").start();
new Thread(()->{
for (int i = 1; i < 40 ; i++) {
ticket.sale();
}
},"B").start();
new Thread(()->{
for (int i = 1; i < 40 ; i++) {
ticket.sale();
}
},"C").start();
}
}
// 资源类 OOP
class Ticket {
// 属性、方法
private int number = 30;
// 卖票的方式
// synchronized 本质: 队列,锁
public synchronized void sale(){
if (number>0){
System.out.println(Thread.currentThread().getName()+"卖出了"+(number--)+"票,剩余:"+number);
}
}
}
结果:
A卖出了30票,剩余:29
A卖出了29票,剩余:28
A卖出了28票,剩余:27
A卖出了27票,剩余:26
A卖出了26票,剩余:25
A卖出了25票,剩余:24
A卖出了24票,剩余:23
A卖出了23票,剩余:22
A卖出了22票,剩余:21
A卖出了21票,剩余:20
A卖出了20票,剩余:19
A卖出了19票,剩余:18
A卖出了18票,剩余:17
A卖出了17票,剩余:16
A卖出了16票,剩余:15
A卖出了15票,剩余:14
A卖出了14票,剩余:13
A卖出了13票,剩余:12
A卖出了12票,剩余:11
A卖出了11票,剩余:10
A卖出了10票,剩余:9
A卖出了9票,剩余:8
A卖出了8票,剩余:7
A卖出了7票,剩余:6
A卖出了6票,剩余:5
A卖出了5票,剩余:4
A卖出了4票,剩余:3
A卖出了3票,剩余:2
A卖出了2票,剩余:1
A卖出了1票,剩余:0
Lock接口来实现
可以看JDK1.8的帮助文档。
package com.cc.demo1;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class SaleTicketDemo02 {
public static void main(String[] args) {
// 并发:多线程操作同一个资源类, 把资源类丢入线程
Ticket2 ticket = new Ticket2();
new Thread(()->{for (int i = 1; i < 40 ; i++)
ticket.sale();},"A").start();
new Thread(()->{for (int i = 1; i < 40 ; i++)
ticket.sale();},"B").start();
new Thread(()->{for (int i = 1; i < 40 ; i++)
ticket.sale();},"C").start();
}
}
// Lock三部曲
// 1、 new ReentrantLock();
// 2、 lock.lock(); // 加锁
// 3、 finally=> lock.unlock(); // 解锁
class Ticket2 {
// 属性、方法
private int number = 30;
Lock lock = new ReentrantLock();
public void sale(){
lock.lock(); // 加锁
try {
// 业务代码
if (number>0){
System.out.println(Thread.currentThread().getName()+"卖出了"+ (number--)+"票,剩余:"+number);
}
} catch (Exception e) {
e.printStackTrace();
} finally {
lock.unlock(); // 解锁
}
}
}
Synchronized和Lock区别
1、Synchronized 内置的Java关键字, Lock 是一个Java类
2、Synchronized 无法判断获取锁的状态,Lock 可以判断是否获取到了锁
3、Synchronized 会自动释放锁,lock 必须要手动释放锁!如果不释放锁,死锁
4、Synchronized 线程 1(获得锁,阻塞)、线程2(等待,傻傻的等);Lock锁就不一定会等待下 去;
5、Synchronized 可重入锁,不可以中断的,非公平;Lock ,可重入锁,可以 判断锁,非公平(可以 自己设置);
6、Synchronized 适合锁少量的代码同步问题,Lock 适合锁大量的同步代码!