上次总结了Synchronized机制下的锁的种类和原理,这次总结一下几种锁的适用场景。
偏向锁
一个线程获取某个对象的偏向锁的成本是很低的,只需把对象头的偏向线程id改为自己就好,如果偏向线程id已经为自己则直接获得锁。当偏向锁的获取出现竞争,则偏向锁可能会升级为轻量级锁。
根据这些,可以看出偏向锁适合无竞争、竞争小的场景,理想的情况为总是由同一个线程去访问同步块、获取某个对象的锁。实际应用中,很多时候情景也确实是这样的。
轻量级锁
轻量级锁由偏向锁升级而来,特点是获取轻量级锁的是通过CAS原子操作进行的,失败的线程不会进入阻塞,而是自旋尝试再次CAS去获取锁。若失败的次数过多,则轻量级锁会膨胀为重量级锁。因为自旋也是要消耗cpu的,不能让线程一直自旋下去。
根据这些,可以看出 轻量级锁最适合场景是追求响应时间的情景,理想的情况是少量线程交替访问同步块、获取锁。若多个线程访问同步块的时间重合的比骄密集就会发生很多自旋造成cpu资源浪费。
重量级锁
重量级锁是轻量级锁受到激烈竞争时,为防止cpu被自旋的线程浪费膨胀而来,因此重量级锁肯定是应付大量线程同时访问同步块的情景。让申请锁失败的线程阻塞后,cpu的负担会减小不少,因此数据的吞吐量也就上来了。
汇总表格: