jdk中提供的并发操作的原子类,如AtomicInteger,的compareAndSwap是比较值Integer的值,那么AtomicReference<V>是比较2个对象的的地址吗?
jdk中提供的并发操作的原子类,如AtomicInteger,的compareAndSwap是比较值Integer的值,那么AtomicReference<V>是比较2个对象的的地址吗?
就如题主所说的,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;
这里,unsafe
的objectFieldOffset
方法是拿到对象的内存偏移量,即通过这里的比较即可判断是否同一个对象地址。
所以,得出结论:
Atomic原子类CAS操作比较的是内存偏移量,即内存地址。
12 回答6k 阅读
2 回答3.2k 阅读✓ 已解决
3 回答7k 阅读✓ 已解决
3 回答3k 阅读✓ 已解决
5 回答4.6k 阅读
4 回答2.3k 阅读
3 回答4.7k 阅读
是地址,准确的说是this对象的内存valueOffset的位置的值和expect比较.
Unsafe详解