synchronized和ReentrantLock区别

  • 相同点

都是用来协调多线程对共享对象、变量的访问都是可重入锁,同一线程可以多次获得同一个锁,都保证了可见性和互斥性。

  • 不同点

1、底层实现不一样,synchronized它是java语言的关键字,是原生语法层面的互斥,需要jvm实现。而ReentrantLock它是JDK 1.5之后提供的API层面的互斥锁,需要lock()和unlock()方法配合try/finally语句块来完成。也就是说synchronized隐式获得释放锁,ReentrantLock 显示的获得、释放锁。

附源码 :

synchronized字节码

ReentrantLock API 

2、synchronized在发生异常时,会自动释放线程占有的锁,因此不会导致死锁现象发生;而Lock 在发生异常时,如果没有主动通过unLock()去释放锁,则很可能造成死锁现象,因此使用Lock 时需要在 finally块中释放锁。

3、synchronized是同步阻塞,使用的是悲观并发策略,lock是同步非阻塞,采用的是乐观并发策略。

4、ReentrantLock可以让等待锁的线程响应中断,而synchronized却不行,使用synchronized时,等待的线程会一直等待下去,不能够响应中断。通过ReentrantLock可以知道有没有成功获取锁,而synchronized却无法办到。最重要的是ReentrantLock可以提供公平锁,而synchronized只能是非公平锁。公平锁、非公平锁,这里写一个示例代码:

 首先重写ReentrantLock中的getQueuedThreads方法(便于观察日志输出)

getQueuedThreads

定义线程

 公平锁执行结果

可以看出公平锁锁是按顺序执行的,而非公平锁没有按顺序执行。ReentrantLock默认是非公平锁,需要创建的时候设置为true标识公平锁。

5、ReentrantLock可以提高多个线程进行读操作的效率,实现读写锁。

读写锁

读写锁执行

读写锁执行结果

可以有多个线程同时读,但是当出现写操作时,就只能有一个线程操作。

6、ReentrantLock通过Condition可以绑定多个条件。

 

转载来源:https://baijiahao.baidu.com/s?id=1652543241208099679&wfr=spider&for=pc

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值