博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
深入理解reentrantlock
阅读量:5150 次
发布时间:2019-06-13

本文共 1423 字,大约阅读时间需要 4 分钟。

reentrantlock指的是可重入锁,concurrent包下面,
private Lock lock = new ReentrantLock(); public void test(){    lock.lock();    try{        do();    }catch (Exception e){        throw e;    }finally {        lock.unlock();    }}

reentrantlock和synchronized很像 都是重入锁

但是感觉reentrantlock更加强大

  • reentrantlock 比synchronized 更加灵活 synchronized 加锁中必须按顺序加减锁 reentrantlock 随意
  • reentrantlock可以指定公平锁和非公平锁
  • reentrantlock 可以中断阻塞队列中的线程
  • reentrantlock可以指定唤醒一个线程 synchronized随机唤醒 notify()
  • 公平锁保证操作顺序 保证每个都执行
final void lock() {     //cas方法比较状态是否为1,如果为0,就把状态改为1,并获得锁    if (compareAndSetState(0, 1))        setExclusiveOwnerThread(Thread.currentThread());    //否则就再次请求一次。    else        acquire(1);}
acquire源码
/**抢占模式或者非公平锁*/final boolean nonfairTryAcquire(int acquires) {    final Thread current = Thread.currentThread();    int c = getState();    if (c == 0) {          //会在去比较一次        if (compareAndSetState(0, acquires)) {            setExclusiveOwnerThread(current);            return true;        }        //是自己占有了锁,重入锁,那就可以再次获得锁,然后修改state    } else if (current == getExclusiveOwnerThread()) {         int nextc = c + acquires;        if (nextc < 0) // overflow            throw new Error("Maximum lock count exceeded");        setState(nextc);        return true;    }    return false;}
  • 公平锁 :有一个queue,阻塞后按顺序加入进去,然后按顺序取出执行。
  • 非公平锁: 抢占锁,不按顺序都可以有机会枪战锁,源码基于链表的结构。

从上面可以看出重入锁只是指的是 如果当前线程拥有资源的锁时候,就可以再次获得锁资源

转载于:https://www.cnblogs.com/tecnologycc/p/9870685.html

你可能感兴趣的文章
帮朋友写的一个自定义选择框
查看>>
CODE[VS] 2221 搬雕像 ——2011年台湾高级中学咨询学科能力竞赛
查看>>
团队冲刺第七天
查看>>
Chrome中的类似Firebug的开发者工具
查看>>
数据结构与算法之--简单排序:冒泡、选择和插入
查看>>
使用dispatch_once实现单例
查看>>
python各模块组合实例
查看>>
【LOJ】#2128. 「HAOI2015」数字串拆分
查看>>
第二阶段--团队冲刺--第四天
查看>>
powershell 操作sharepoint命令集
查看>>
2ge ListBox 之间的 上下选择,MVC ViewModel
查看>>
codevs1314 寻宝
查看>>
POJ 3083 Children of the Candy Corn(DFS + BFS)
查看>>
Java使用ZXing生成/解析二维码图片
查看>>
4.8日学习打卡
查看>>
在linux中文件的权限讲解
查看>>
(最小生成树)Constructing Roads -- poj -- 2421
查看>>
css3画半圆
查看>>
模拟题1
查看>>
linux shell 流程控制
查看>>