前言

Atomic家族主要是保证多线程环境下的原子性,相比synchronized而言更加轻量级。比较常用的是AtomicInteger,作用是对Integer类型操作的封装,而AtomicReference作用是对普通对象的封装。

实例

  1. @Data
  2. @AllArgsConstructor
  3. public class User {
  4. private String name;
  5. private Integer age;
  6. }

使用 AtomicReference 初始化,并赋值

  1. public static void main( String[] args ) {
  2. User user1 = new User("张三", 23);
  3. User user2 = new User("李四", 25);
  4. User user3 = new User("王五", 20);
  5. //初始化为 user1
  6. AtomicReference<User> atomicReference = new AtomicReference<>();
  7. atomicReference.set(user1);
  8. //把 user2 赋给 atomicReference
  9. atomicReference.compareAndSet(user1, user2);
  10. System.out.println(atomicReference.get());
  11. //把 user3 赋给 atomicReference
  12. atomicReference.compareAndSet(user1, user3);
  13. System.out.println(atomicReference.get());
  14. }
  1. User(name=李四, age=25)
  2. User(name=李四, age=25)

解释

compareAndSet(V expect, V update)
该方法作用是:如果atomicReference==expect,就把update赋给atomicReference,否则不做任何处理。
image.png

  • atomicReference的初始值是user1,所以调用compareAndSet(user1, user2),由于user1==user1,所以会把user2赋给atomicReference。此时值为“李四”
  • 第二次调用atomicReference.compareAndSet(user1, user3),由于user2 != user1,所以set失败。atomicReference仍然为“李四”

原文链接:https://www.cnblogs.com/fhblikesky/p/13692643.html