AtomicReference提供线程安全的对象引用更新,通过get、set和compareAndSet等方法实现无锁操作,适用于频繁读取、偶尔更新的场景,如状态标志、配置管理;需注意其仅保证引用原子性,不保证对象内部线程安全,且高竞争下可能因CAS失败导致重试开销。
在Java中,AtomicReference 是 java.util.concurrent.atomic 包提供的一个工具类,用于以原子方式更新对象的引用。它适用于需要线程安全地修改某个对象引用的场景,而无需使用 synchronized 关键字或显式锁。
AtomicReference 可以包装任何类型的对象引用,并提供线程安全的 get、set 和 compareAndSet 等操作。
创建和初始化 AtomicReference 非常简单:
AtomicReferenceref = new AtomicReference<>("初始值"); String oldValue = ref.get(); // 获取当前引用 ref.set("新值"); // 原子性设置新引用
最常用的原子操作之一是 compareAndSet(expe 
示例:线程安全地更新用户状态
AtomicReferenceuserRef = new AtomicReference<>(new User("张三", "在线")); // 模拟某个线程尝试更新状态 User expect = userRef.get(); User update = new User(expect.getName(), "离线"); if (userRef.compareAndSet(expect, update)) { System.out.println("状态更新成功"); } else { System.out.println("有其他线程已修改,更新失败"); }
这个机制能避免竞态条件,确保更新基于最新状态。
AtomicReference 特别适合以下情况:
但要注意:
基本上就这些。AtomicReference 提供了一种轻量级、高效的线程安全引用管理方式,合理使用可以提升并发程序的性能和可读性。