synchronized和ReenTrantLock

 

之前一直以为syn跟Ren的一个区别是可重入,今天测试了一下,syn也是可重入的。

其实jkd1.5开始,syn开始尝试优化,到1.7的时候,性能和ren已经相差无几了,甚至官方还建议使用syn呢。

syn优化了什么?

synchronized内部是这样的:

先是偏向锁,然后从自旋锁过度到轻量级锁,最后才是重量级锁

一方面,syn的使用相对简单,另一方面,官方都这么建议了,那么,我们什么时候使用ren呢?就是我们需要使用到ren的特有功能的时候:

ReenTrantLock独有的能力:

1.      ReenTrantLock可以指定是公平锁还是非公平锁。而synchronized只能是非公平锁。所谓的公平锁就是先等待的线程先获得锁。

2.      ReenTrantLock提供了一个Condition(条件)类,用来实现分组唤醒需要唤醒的线程们,而不是像synchronized要么随机唤醒一个线程要么唤醒全部线程。

3.      ReenTrantLock提供了一种能够中断等待锁的线程的机制,通过lock.lockInterruptibly()来实现这个机制。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值