点个关注,必回关
这两种同步方式有很多相似之处,它们都是加锁方式同步,而且都是阻塞式的同步,也就是说当如
果一个线程获得了对象锁,进入了同步块,其他访问该同步块的线程都必须阻塞在同步块外面等
待,而进行线程阻塞和唤醒的代价是比较高的.
Synchronized
来说,它是java语言的关键字,是原生语法层面的互ReentrantLock
它是JDK 1.5之后提供的API层面的互斥锁,需要lock()和unlock()
方法配合try/finally
语句块来完成。Synchronized
进过编译,会在同步块的前后分别形成monitorenter和monitorexit
这个两个字节码monitorenter
指令时,首先要尝试获取对象锁。如果这个对象没被锁定,或者当前线monitorexit
指令时会将锁计算器就由于ReentrantLock
是java.util.concurrent
包下提供的一套互斥锁,相比Synchronized
,
ReentrantLock类
提供了一些高级功能,主要有以下3项:
等待可中断,持有锁的线程长期不释放的时候,正在等待的线程可以选择放弃等待,这相当于
Synchronized
来说可以避免出现死锁的情况。
公平锁,多个线程等待同一个锁时,必须按照申请锁的时间顺序获得锁,Synchronized
锁非公平
锁,ReentrantLock
默认的构造函数是创建的非公平锁,可以通过参数true
设为公平锁,但公平锁
表现的性能不是很好。
锁绑定多个条件,一个ReentrantLock对象可以同时绑定对个对象。