synchronize底层实现原理以及相关的优化

Posted gzhbk

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了synchronize底层实现原理以及相关的优化相关的知识,希望对你有一定的参考价值。

首先来说下synchronize和Lock的区别:

两者都是锁,用来控制并发冲突,区别在于Lock是个接口,提供的功能更加丰富,除了这个外,他们还有如下区别:

synchronize自动释放锁,而Lock必须手动释放,并且代码中出现异常会导致unlock代码不执行,所以Lock一般在Finally中释放,而synchronize释放锁是由JVM自动执行的。
Lock有共享锁的概念,所以可以设置读写锁提高效率,synchronize不能。(两者都可重入)
Lock可以让线程在获取锁的过程中响应中断,而synchronize不会,线程会一直等待下去。lock.lockInterruptibly()方法会优先响应中断,而不是像lock一样优先去获取锁。
Lock锁的是代码块,synchronize还能锁方法和类。
Lock可以知道线程有没有拿到锁,而synchronize不能(Thread.holdsLock方法可以让synchronize也能感应到是否获取到了锁)
 

Lock锁对应有源码的,可以查看下代码,那么synchronize在JVM层面是怎么实现的呢,我们看下字节码文件:

先用javac Test.class 编译出class文件
再用javap –c Test.class查看字节码文件
我们写个DEMO看下,JVM底层是怎么实现synchronized的:
————————————————
版权声明:本文为CSDN博主「淡定一生2333」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zc19921215/article/details/84780335

以上是关于synchronize底层实现原理以及相关的优化的主要内容,如果未能解决你的问题,请参考以下文章

Java synchronized关键字的底层实现以及锁升级优化的原理一万字

synchronized底层实现原理及锁优化

synchronized底层实现原理及锁优化

synchronized底层实现原理及锁优化

synchronize底层实现原理

Java并发编程:Synchronized底层优化(偏向锁轻量级锁)