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

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

相关推荐
小红的布丁11 小时前
雪花算法:高并发场景下的分布式唯一ID生成方案解析
分布式
鲸能云12 小时前
电力安全监管新规技术解读:分布式新能源电站数字化监控体系建设实践
分布式
8Qi812 小时前
Elasticsearch 初识篇:核心概念与环境搭建
java·大数据·分布式·elasticsearch·搜索引擎·中间件
互联网散修13 小时前
鸿蒙实战:分布式数据对象实现本地、网络视频跨端迁移续播
分布式·harmonyos·跨端迁移
Albert Edison13 小时前
【RabbitMQ】发布 / 订阅模式(使用案例)
分布式·rabbitmq
Ulyanov13 小时前
ZeroMQ在分布式雷达仿真中的应用
分布式·python·信号处理·系统仿真·雷达电子对抗
身如柳絮随风扬13 小时前
分布式锁深度剖析:ZooKeeper(CP)与 Redis(AP)的实现原理与对比
redis·分布式·zookeeper
_下雨天.13 小时前
Zookeeper+Kafka消息队列单节点与集群部署
分布式·zookeeper·kafka
卢傢蕊14 小时前
Kafka 消息队列
分布式·kafka·java-zookeeper
richard_yuu14 小时前
软件架构与工具:深度解析分布式协调与动态重配置管理
分布式