并发编程-并发机制的底层实现原理pdf篇

本文深入探讨Java并发编程的底层实现,包括Java对象头、锁的升级(偏向锁、轻量级锁、重量级锁)原理、volatile与synchronized实现机制,以及原子操作的细节。了解这些原理有助于提升并发编程效率。
摘要由CSDN通过智能技术生成

ava 代码在编译后变成 Java 字节码,字节码被类加载器加载到 JVM里执行,最终转换为汇编指令在CPU上执行,Java 中所所使用的并发机制依赖于 JVM 的实现和 CPU 指令;Java 中的大部分并发容器和框架依赖于 volatile 和原子操作的实现原理,了解这些原理对我们进行并发编程会有所帮助。

本文将依次介绍:CPU术语、Java对象头、锁的升级与对比、volatile 实现原理、synchronized 实现原理、原子操作的实现原理。

CPU术语

Java对象头

如果对象是数组类型,则虚拟机用3个字宽(Word)存储悐头,如果对象是非数组类型,则用2个字宽存储对象头。在32位虚拟机中,1字宽等于4字节,即32bit,如表2-2所示。

Java对象头里的Mark Word里默认存储对象的HashCode、分代年龄和锁标记位。32位JVM的Mark Word的默认存储结构如表2-3所示。

在运行期间,Mark Word里存储的数据会随着锁标志位的变化而变化。Mark Work可能变化为存储以下4种数据,如表2-4所示。

在64位虚拟机下,Mark Word是64bit大小的, 其存储结构如图2-5所示。

锁的升级与对比

Java SE 1.6 为了减少获得锁和释放锁带来的性能消耗,引

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值