高并发是从1.5到1.6的一个重要的改进,HotSpot虚拟机开发团队在这个版本上话费了大量的精力去实现各种锁优化:
1.自旋锁与自适应锁
:许多应用上共享数据的锁定状态只会持续很短的时间,为了这段时间去挂起和恢复线程并不值当得。为了让线程等待,我们只需要让线程执行一个忙循环(自旋),这项技术就是所谓的自旋锁了。这个是JDK1.4.2引入的默认是关闭的,JDK1.6默认开启。
JDK 1.6引入了自适应的自旋锁,自适应意味着自旋的时间不再固定了,而是由前一次在同一个锁上的自旋时间及锁的拥有者的状态来决定。
2.锁消除
是指虚拟机即时编译器在运行的时,对一些代码上要求同步,但是被检测都不可能存在共享数据竞争的锁进行消除。
3.锁粗化
-但是如果一系列的连续操作都对同一个对象反复加锁和解锁,甚至加锁擦欧哦出现在循环体中的,那即使没有线程竞争,频繁地进行互斥同步操作也会导致不必要的性能损耗。如果虚拟机探测到有这样的操作对同一个对象加锁,将会把加锁同步的范围扩展(粗化)到整个操作序列的外部。
4.轻量级锁
-是JDK 1.6加入的新型锁,是相对于使用操作系统互斥量来实现的传统锁而言的。是在无竞争的情况下使用CAS操作去消除使用的互斥量。
5.偏向锁
-是JDK 1.6加入的新型锁,是在无竞争的情况下把整个同步都消除,连CAS操作都不做了。
网友评论