synchronize锁和ReentrantLock锁

首先ReentrantLock是一个非公平锁,但也是可以变成公平锁的(传入参数true即可),

就是ReentrantLock locker=new ReentrantLock(true);

ReentrantLock的唤醒机制是搭配Condition类来实现的,可以实现为唤醒指定的等待线程.

而synchronized锁是搭配wait 和notify来实现唤醒的且唤醒机制是随机唤醒一个线程,不可唤醒一个指定的线程

ReentrantLock还有一个优势是有一个tryLock来试图上锁,加锁成功则就加了锁,加锁不成功就放弃呗~~,并且还可以设置加锁的等待超时时间,而实际开发过程中很多死等的情况,所以说tryLock给我们提供了更多的可能

但是ReentrantLock也有一个缺点,他的上锁和解锁是分开的连个方法,这就导致了可能刚上完锁后面出现异常或者return返回了,就没有解锁这个行为了,所以一般把locker.lock();放在try里面,若果有异常,把locker.unlock()解锁放在finally里面就保证不会忘记解锁了

由于synchronized锁的自适应性,这导致了synchronized既是一个乐观锁也是一个悲观锁,既是一个轻量级锁也是一个重量级锁,轻量级锁是基于自旋锁来实现的,重量级锁是基于挂起等待锁实现的,不是读写锁(是普通互斥锁),不是公平锁(是非公平锁),是可重入锁.

还有一个微乎其微的区别:

synchronized锁是Java的关键字,底层是JVM实现的(C++写的)

ReentrantLock锁是java的标准库里面的,底层是java写的

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值