Lock 锁是 JDK 5.0 新增的线程安全问题解决方式
接着上一篇同步代码(synchronized)解决线程安全问题:https://blog.csdn.net/lijibai_/article/details/123798469
今天我们来看看另一种性能更好的线程安全方式:Lock 锁
目录
synchronized与Lock的对比
1. Lock 是显式锁(手动开启和关闭锁),synchronized 是隐式锁,出了作用域自动释放
2. Lock 只有代码块锁,synchronized 有代码块锁和方法锁
3. 使用 Lock 锁,JVM 将花费较少的时间来调度线程,性能更好。并且具有更好的扩展性(提供更多的子类)
锁的优先使用顺序
Lock ——> 同步代码块(已经进入方法体,分配了相应资源)——> 同步方法(方法体之外)
Lock锁代码举例
import java.util.concurrent.locks.ReentrantLock;
class window implements Runnable{
private int ticket = 100;
//1. 实例化ReentrantLock
private ReentrantLock lock = new ReentrantLock();
@Override
public void run() {
while(true){
try {
//2. 调用锁定方法Lock()
lock.lock();
if (ticket > 0) {
try{
Thread.sleep(100);
} catch(InterruptedException e){
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + ":号码为" + ticket);
ticket--;
}else{
break;
}
}finally{
//3. 调用解锁方法:unlock()
lock.unlock();
}
}
}
}
public class lockTest {
public static void main(String[] args) {
window w = new window();
Thread t = new Thread(w);
Thread t1 = new Thread(w);
t.start();
t1.start();
}
}
版权声明:本文为lijibai_原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。