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等函数式方法

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

相关推荐
西红柿维生素20 小时前
zk管理kafka&kafka-broker通信
分布式·kafka
陈平安Java and C20 小时前
分布式链路追踪-SkyWalking
分布式·skywalking
鳄鱼杆20 小时前
分布式 | 布隆过滤器实战指南:原理、编码实现、应用与Redisson最佳实践
分布式
whltaoin1 天前
SpringCloud项目阶段八:利用redis分布式锁解决集群状态下任务抢占以及实现延迟队列异步审核文章
redis·分布式·spring cloud
失散131 天前
分布式专题——15 ZooKeeper特性与节点数据类型详解
java·分布式·zookeeper·云原生·架构
菠菠萝宝1 天前
【Java八股文】12-分布式面试篇
java·分布式·zookeeper·面试·seata·redisson
日月星辰Ace1 天前
Spring Cloud Sleuth 和 Zipkin 详解
分布式
失散131 天前
分布式专题——20 Kafka快速入门
java·分布式·云原生·架构·kafka
猫林老师1 天前
实战:基于HarmonyOS 5构建分布式聊天通讯应用
分布式·wpf·harmonyos
爱敲代码的TOM1 天前
微服务基础3-服务保护与分布式事务
分布式·微服务·架构