AtomicReference用于原子更新对象引用,保证引用赋值的原子性,适用于无锁更新配置、状态机切换等场景,通过compareAndSet实现CAS操作,结合循环重试或函数式方法getAndUpdate/accumulateAndGet可安全修改共享引用,但不保证对象内部线程安全,需注意高并发下CAS失败率及引用相等性判断问题。

在Java并发编程中,AtomicReference 是一个非常有用的工具类,用于实现对象引用的原子更新。它位于 java.util.concurrent.atomic 包下,适用于需要无锁地安全更新共享对象引用的场景。
AtomicReference的基本作用
与 AtomicInteger 等原子类类似,AtomicReference 提供了对对象引用的原子操作能力。它不保证对象本身的线程安全,而是保证“引用赋值”这一动作是原子的。适用于状态对象、配置信息、缓存实例等需要动态替换的引用类型。
常见使用场景包括:
无锁更新服务配置对象 实现线程安全的状态机切换 替代 volatile 配合 CAS 实现更灵活的并发控制
基本用法示例
创建一个 AtomicReference 并进行原子更新:
立即学习“Java免费学习笔记(深入)”;
// 定义一个简单的状态类class State { final String name; final int value; State(String name, int value) { this.name = name; this.value = value; } @Override public String toString() { return "State{" + "name='" + name + '\'' + ", value=" + value + '}'; }}// 使用AtomicReference管理状态对象AtomicReference stateRef = new AtomicReference(new State("INIT", 0));// 原子获取当前值State currentState = stateRef.get();// 原子设置新值stateRef.set(new State("RUNNING", 1));// CAS方式更新:期望是INIT状态时才更新为STARTINGState expected = currentState;State update = new State("STARTING", 2);boolean success = stateRef.compareAndSet(expected, update);if (success) { System.out.println("更新成功");} else { System.out.println("更新失败,引用已被其他线程修改");}
compareAndSet 与 weakCompareAndSet 的区别
compareAndSet 是强保证的CAS操作,成功则一定完成更新,失败则说明当前值不等于预期值。
weakCompareAndSet 在某些平台上可能以更低的开销执行,但允许偶然失败(即使值匹配也可能失败),通常建议优先使用 compareAndSet。
音疯
音疯是昆仑万维推出的一个AI音乐创作平台,每日可以免费生成6首歌曲。
146 查看详情
典型模式:循环重试直到更新成功
for (;;) { State oldState = stateRef.get(); State newState = modify(oldState); // 根据旧状态生成新状态 if (stateRef.compareAndSet(oldState, newState)) { break; // 成功退出 } // 失败则重试,读取最新值继续}
结合函数式更新(JDK 8+)
AtomicReference 提供了 accumulateAndGet 和 getAndUpdate 方法,支持基于函数式的更新逻辑:
// 将当前状态的value加1,并返回更新前的值State prev = stateRef.getAndUpdate(current -> new State(current.name, current.value + 1));// 基于当前值计算并返回结果int newValue = stateRef.accumulateAndGet( new State("ADD", 10), (current, update) -> new State(current.name, current.value + update.value)).value;
这些方法简化了状态转换逻辑,避免手动编写CAS重试循环。
注意事项
使用 AtomicReference 时需注意以下几点:
只保证引用的原子性,不保护对象内部状态,若对象可变,仍需额外同步 适合低竞争场景,高并发下大量CAS失败可能导致性能下降 不要依赖引用相等性判断,特别是在对象重建时 避免在 lambda 中持有长时间运行的操作,影响更新效率
基本上就这些。AtomicReference 是实现无锁并发的重要组件之一,合理使用可以在保证线程安全的同时减少锁开销。
以上就是Java里如何使用AtomicReference管理对象原子更新_AtomicReference使用方法解析的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1075411.html
微信扫一扫
支付宝扫一扫