深入理解reentrantlock

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值