• 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

  • 相关阅读:
    L2 L3 L4
    C 语言assert使用
    VIM 命令收藏
    C++继承实例
    关于 WinScp 的一点使用经验
    Boa服务器移植
    Android 去掉标题全屏显示
    sys下gpio操作
    linux下 XGCOM串口助手的安装
    linux中inittab文件详解
  • 原文地址:https://www.cnblogs.com/gzhbk/p/13235228.html
Copyright © 2020-2023  润新知