atomic常用类方法

Java中的java.util.concurrent.atomic包提供了多种原子操作工具类,以下是核心类及其方法:


1. AtomicBoolean

方法‌:

  • get():获取当前值
  • set(boolean newValue):强制设置值
  • compareAndSet(boolean expect, boolean update):CAS操作
  • getAndSet(boolean newValue):原子获取旧值并设置新值
  • lazySet(boolean newValue):最终一致性设置(不保证立即可见)

2. AtomicInteger/AtomicLong

方法‌:

  • get()/intValue():获取当前值
  • set(int newValue):强制设置值
  • compareAndSet(int expect, int update):CAS操作
  • getAndIncrement():原子自增(返回旧值)
  • getAndDecrement():原子自减
  • getAndAdd(int delta):原子加法
  • incrementAndGet():自增并返回新值
  • updateAndGet(IntUnaryOperator updateFunction):函数式更新

‌**3. AtomicReference<V>**‌

方法‌:

  • get():获取引用值
  • set(V newValue):强制设置引用
  • compareAndSet(V expect, V update):CAS操作
  • getAndSet(V newValue):原子交换引用
  • updateAndGet(UnaryOperator<V> updateFunction):函数式更新引用

4. AtomicIntegerArray/AtomicLongArray

方法‌:

  • length():数组长度
  • get(int i):获取下标i的值
  • set(int i, int newValue):设置指定下标值
  • compareAndSet(int i, int expect, int update):CAS操作指定元素
  • getAndIncrement(int i):原子自增数组元素

‌**5. AtomicStampedReference<V>**‌

方法‌:

  • getReference():获取引用值
  • getStamp():获取版本戳
  • compareAndSet(V expectedReference, V newReference, int expectedStamp, int newStamp):带版本戳的CAS

‌**6. AtomicMarkableReference<V>**‌

方法‌:

  • isMarked():获取标记状态
  • compareAndSet(V expectedReference, V newReference, boolean expectedMark, boolean newMark):带标记位的CAS

‌**7. LongAdder/DoubleAdder(高并发统计场景)**‌

方法‌:

  • add(long x):累加值
  • sum():返回总和(非原子)
  • reset():重置计数器

特点总结‌:

  1. 线程安全‌:所有操作均为原子性
  2. 无锁设计‌:基于CAS实现高性能并发
  3. 内存语义 ‌:遵循volatile的可见性和有序性
  4. 函数式支持 ‌:JDK8+提供updateAndGet等函数式方法

适用于计数器、状态标志、对象引用更新等场景。

相关推荐
lang201509281 小时前
深入解析Kafka核心:Partition类源码揭秘
分布式·kafka·linq
Blossom.1181 小时前
基于图神经网络+大模型的网络安全APT检测系统:从流量日志到攻击链溯源的实战落地
人工智能·分布式·深度学习·安全·web安全·开源软件·embedding
梦里不知身是客112 小时前
spark如何调节jvm的连接等待时长
大数据·分布式·spark
梦里不知身是客112 小时前
spark的血脉机制
大数据·分布式·spark
Query*3 小时前
分布式消息队列kafka【六】—— kafka整合数据同步神器canal
分布式·kafka
2301_807288633 小时前
MPRPC项目(第七天,rpcprovider分发rpc服务)
网络·分布式·rpc
L、2183 小时前
深入实战:使用 Platform Channel 实现 Flutter 与 OpenHarmony 原生能力互通
分布式·flutter·harmonyos
Cat God 0073 小时前
Kafka单机搭建(二)
分布式·kafka·linq
shjita3 小时前
hadoop运行jar包的相关配置参考!
大数据·hadoop·分布式