Java原子类:CAS与volatile的无锁奥秘

Java中的原子类位于java.util.concurrent.atomic包下,根据功能可分为四类,其核心原理均基于 volatile变量保证内存可见性CAS(Compare-and-Swap)操作保证原子性


⚛️ 一、基本类型原子类

  1. AtomicBoolean
    • 原理 :内部用volatile int value存储状态(0=false,1=true),通过Unsafe的compareAndSwapInt实现原子更新。
  2. AtomicInteger
    • 原理 :通过volatile int value存储值,使用Unsafe的getAndAddInt等CAS操作实现原子增减(如incrementAndGet())。
  3. AtomicLong
    • 原理 :类似AtomicInteger,使用volatile long value和CAS操作;64位系统需处理64位对齐问题。

🔢 二、数组类型原子类

  1. AtomicIntegerArray
    • 原理 :内部维护final int[] array,计算元素偏移地址后通过Unsafe的CAS操作数组元素。
  2. AtomicLongArray
    • 原理 :类似AtomicIntegerArray,支持long数组的原子操作。
  3. AtomicReferenceArray
    • 原理 :通过偏移地址和compareAndSwapObject实现引用类型数组元素的原子替换。

🔗 三、引用类型原子类

  1. AtomicReference<V>
    • 原理 :通过volatile V value存储引用,Unsafe的compareAndSwapObject实现引用的原子替换。
  2. AtomicStampedReference<V>
    • 原理 :在引用基础上增加int stamp(版本戳),解决CAS的ABA问题(同时检查引用和版本戳)。
  3. AtomicMarkableReference<V>
    • 原理 :用布尔标记(boolean mark)替代版本戳,简化ABA问题处理。

🛠️ 四、字段更新器

  1. AtomicIntegerFieldUpdater<T>
    • 原理 :通过反射更新目标类的volatile int字段,底层使用CAS保证原子性。
  2. AtomicLongFieldUpdater<T>
    • 原理 :类似上述,支持long字段。
  3. AtomicReferenceFieldUpdater<T,V>
    • 原理:支持引用类型字段的原子更新,依赖反射和CAS。

🔬 原理共性总结

  1. 内存可见性 :所有原子类内部使用volatile修饰变量,确保多线程下读取最新值。
  2. 原子性保障 :依赖Unsafe类的CAS操作(如compareAndSwapInt),自旋重试直到更新成功。
  3. 无锁优化 :相比synchronized,CAS避免线程阻塞,提升高并发性能。

⚠️ 注意:原子类仅适用于单个变量的简单操作(如增减、替换)。复杂逻辑仍需锁或其他同步机制。

相关推荐
高山上有一只小老虎几秒前
判断是否为数独数组
java·算法
好学且牛逼的马4 分钟前
【手写Mybatis | version0.0.3 附带源码 项目文档】
开发语言·php·mybatis
okseekw4 分钟前
File类:你与文件的"爱恨情仇"——Java文件操作的趣味指南
java·后端
海上彼尚5 分钟前
Go之路 - 2.go的常量变量[完整版]
开发语言·后端·golang
梨落秋霜7 分钟前
Python入门篇【if判断语句】
android·java·python
萝卜白菜。7 分钟前
关于maxPartCount和maxPartHeaderSize参数的限制说明
java·tomcat
kkk_皮蛋9 分钟前
深入理解 WebRTC 临界锁实现与 C++ RAII 机制
开发语言·c++·webrtc
i_am_a_div_日积月累_10 分钟前
el-table实现自动滚动;列表自动滚动
开发语言·javascript·vue.js
Li_76953211 分钟前
Spring Cloud —— SkyWalking(五)
java·后端·spring·spring cloud·skywalking
嘟嘟w12 分钟前
Forward(转发)与Redirect(重定向)的区别
java