【Java笔记】Lock锁方式解决线程安全问题

Lock 锁是 JDK 5.0 新增的线程安全问题解决方式

接着上一篇同步代码(synchronized)解决线程安全问题:https://blog.csdn.net/lijibai_/article/details/123798469

今天我们来看看另一种性能更好的线程安全方式:Lock 锁

目录

synchronized与Lock的对比

锁的优先使用顺序

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版权协议,转载请附上原文出处链接和本声明。