AtomicReferencecompareAndSwap是比较对象的地址吗

发布于 2022-09-04 12:05:17 字数 247 浏览 18 评论 0

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

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

白色秋天 2022-09-11 12:05:17

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

七堇年 2022-09-11 12:05:17

就如题主所说的,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操作比较的是内存偏移量,即内存地址。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文