AtomicReference<V> compareAndSwap是比较对象的地址吗

jdk中提供的并发操作的原子类,如AtomicInteger,的compareAndSwap是比较值Integer的值,那么AtomicReference<V>是比较2个对象的的地址吗?
clipboard.png

阅读 5.2k
2 个回答

是地址,准确的说是this对象的内存valueOffset的位置的值和expect比较.
Unsafe详解

就如题主所说的,AtomicInteger源码是比较并替换Integer来实现线程安全性。而AtomicReference是相比于对象引用的比较并替换。这些都是原子类CAS实现。

至于是不是比较地址,先拿题主所说的AtomicReference入手,知道下面的方法:

public final boolean compareAndSet(V expect, V update) {
    return unsafe.compareAndSwapObject(this, valueOffset, expect, update);
}

底层实现在Unsafe类中,是一个native本地方法。Unsafe的CAS包括了三个操作数--需要读写的内存位置valueOffset,进行比较的值expected,拟定写入的新值update。当且仅当在内存位置V所存储的值等于比较的值A时,CAS才会通过原子方式用新值来更新内存地址的旧值。否则不进行任何操作。

关键在于传入的valueOffset的作用,继续查看AtomicReference源码:

static {
  try {
    valueOffset = unsafe.objectFieldOffset
        (AtomicReference.class.getDeclaredField("value"));
  } catch (Exception ex) { throw new Error(ex); }
}

private volatile V value;

这里,unsafeobjectFieldOffset方法是拿到对象的内存偏移量,即通过这里的比较即可判断是否同一个对象地址。

所以,得出结论:

Atomic原子类CAS操作比较的是内存偏移量,即内存地址。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题
宣传栏