第二章-Java并发机制的底层实现原理

Java并发机制的底层实现原理

Java代码的一生:

  1. 编译后变成Java字节码
  2. 字节码被类加载器加载到jvm
  3. jvm执行字节码,最终转换为汇编指令在CPU上运行

Java中使用的并发机制依赖于jvm的实现和CPU指令。

2.1 - volatile的应用

volatile是轻量级的synchronized. 保证共享变量的可见性.

可见性:一个线程修改共享变量后,另外一个线程能读到修改后的值

因为不会引起线程上下文切换和调度,所以会比synchronized成本更低。

2.1.1 - volatile的定义和实现

Java语言规范对其定义:

Java允许线程访问共享变量,为了确保共享变量能被准确和一致性更新,线程应通过排它锁单独获得这个变量

Java提供了volatile, 比排它锁更方便。如果一个字段被修饰成volatile,Java内存模型会保证所有线程看到的值都是一致的.

volatile如何保证可见性:

  1. 修饰的变量在转换为汇编指令时,会有一个Lock前缀的指令
  2. 这个指令引发两件事:
    • 将当前处理器缓存行的数据写回到系统内存
    • 写回内存的操作会使在其他CPU里缓存了该内存地址的数据失效

为了提高处理器速度,不直接和内存进行通信。而是将系统内存的数据读到内部缓存再进行操作。

2.2 synchronized

Java中的每一个对象都可以是锁。synchronized实现同步的基础:

  1. 普通同步方法: 锁是当前实例对象
  2. 静态同步方法: 锁是当前类的class对象
  3. 同步方法块: 锁是括号里配置的对象

jvm规范中可以看到synchronized的实现原理:

  1. jvm通过进入和退出Monitor对象来实现方法同步和代码块同步,但实现细节不一样
  2. 代码块:使用monitorenter和monitorexit指令实现
  3. 方法同步: 另外一种
monitorenter指令:在编译后期插入到同步代码块开始位置
monitorexit指令: 插入到方法结束和异常处
1. jvm保证每个monitorenter都有一个monitorexit对应。
2. 任何一个对象都有一个monitor对象关联。并且一个monitor对象被持有后,将处于锁定状态
3. 线程执行到monitorenter指令时,会尝试获取对象所对应的monitor的所有权,即尝试获取对象的锁
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,510评论 11 349
  • 并发系列的文章都是根据阅读《Java 并发编程的艺术》这本书总结而来,想更深入学习的同学可以自行购买此书进行学习。...
    小之丶阅读 4,342评论 0 10
  • Java8张图 11、字符串不变性 12、equals()方法、hashCode()方法的区别 13、...
    Miley_MOJIE阅读 9,181评论 0 11
  • 雪花落 黑发飘 染白了青丝 融化了暮朝 梨花 落满树 思念 铺满路 嬉笑着虚度 聚散得慷慨 迷醒的岁月中 贫瘠的未...
    今年只爱学习阅读 3,180评论 0 3
  • 在周围朋友的印象里,Uber算是一个比较有调性的产品,相对于其他用车类产品滴滴、易到等的接地气,Uber总显得稍微...
    周末77阅读 3,723评论 0 4

友情链接更多精彩内容