ReentrantLock总结

简述

ReentrantLock是java中非常重要的一个并发工具,相比于java原生的synchronized有着更好的性能

## 概念速查
ReentrantLock涉及的名称和概念较多,这里做一个简单的归类和解释,具体更为详细的内容,请自行Baidu或Google,这部分用于在阅读文章的时候,快速了解一些名称的概念,如果已经熟悉,请跳过。

快速预览

更强大的功能,玩玩意味着更为复杂的使用,ReentrankLock的使用比起synchronize,多了一个主动释放锁的代码,一个典型的使用示例如下

ReentrantLock lock = new ReentrantLock();
lock.lock();
try {
    // ... method body
}finally {
    lock.unlock();
}

注意unlock的操作一定要置于finally块中,这样才能保证锁一定能释放。

uml图

看完了简单的使用示例,我们来快速的看一遍ReentrankLock的结构,下面是用idea的工具快速生成的uml图,感谢idea,大大提高了我们的工作质量。

ReentrantLock-UML

一次性过于深入的讨论,往往会迷失在繁琐的细节中,而难以把握全貌,而细节往往是由全局的目标决定的,所以我们一层一层的谈,不一次性深入最终代码。

由uml图,我们可以看出,ReentrantLock类是一个Lock接口的具体实现,每个ReentrantLock的实例,都持有一个sync对象,且这个sync是final修饰的,这个sync有两种具体的子类,分别是NonfairSync和FairSync,也就是非公平锁和公平锁。

ReentrantLock有两个构造方法,我们可以先看这两个方法,

public ReentrantLock() {
    sync = new NonfairSync();
}
public ReentrantLock(boolean fair) {
    sync = (fair)? new FairSync() : new NonfairSync();
}

可以看出,所谓构造函数,其实就是初始化需要使用的sync的类型,默认是非公平锁。参考公平锁与非公平锁

案例:并发卖火车票

public class Ticket implements Runnable {
// 当前拥有的票数
private int num = 100;
ReentrantLock lock = new ReentrantLock();

public void run() {
    while (true) {
        try {
            Thread.sleep(10);
        } catch (InterruptedException e) {
        }
        lock.lock();
        // 输出卖票信息
        if (num > 0) {
            System.out.println(Thread.currentThread().getName() + ".....sale...." + num--);
        }
        lock.unlock();
   }
}
}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 简述 ReentrantLock是java中非常重要的一个并发工具,相比于java原生的synchronized有...
    饭团爸爸v5阅读 3,449评论 0 0
  • 作者: 一字马胡 转载标志 【2017-11-03】 更新日志 前言 在java中,锁是实现并发的关键组件,多个...
    一字马胡阅读 44,229评论 1 32
  • 2018年3月4号 第一次有被催稿的感觉,粉丝们等着我的画来写文字发朋友圈,一下子有种受宠若惊的感觉。 老铁蓝姐知...
    凤姐手工阅读 1,358评论 0 4
  • 【2017年03月15星期五——咖啡冥想】 财富目标:保险业绩每个月不少于100万,保险收入不少于10万,新公司三...
    热瓦昆空阅读 1,215评论 0 2
  • 最近一直再修改项目中遗留的BUG,现在将项目中存在的一些可能出现的比较莫名其妙的错误记录一下,供可能出现同类问题的...
    mark666阅读 5,743评论 2 7