本文内容:
- 分析原子类AtomicReference
- 分析源码
AtomicReference中
public final boolean compareAndSet(V expect, V update) {
return unsafe.compareAndSwapObject(this, valueOffset, expect, update);
}
public final V getAndSet(V newValue) {
return (V)unsafe.getAndSetObject(this, valueOffset, newValue);
}
public final Object getAndSetObject(Object var1, long var2, Object var4) {
Object var5;
do {
var5 = this.getObjectVolatile(var1, var2);
} while(!this.compareAndSwapObject(var1, var2, var5, var4));
return var5;
}
compareAndSwapObject 源码探析
public final native boolean compareAndSwapObject(Object var1, long var2, Object var4, Object var5);
可以看到声明的是native方法,意味着该方法使用更底层的代码(cpp)实现的,需要下载openjdk源码才可以看到。下面开始简要地介绍下寻找源码的过程。
下载好openjdk源码后,将其导入到idea里该project的lib中,方便全局查找。
参照native实现规则,可以猜测javah工具生成的cpp头文件。
UNSAFE_ENTRY(jboolean, Unsafe_CompareAndSwapObject(JNIEnv *env, jobject unsafe, jobject obj, jlong offset, jobject e_h, jobject x_h))
UnsafeWrapper("Unsafe_CompareAndSwapObject");
oop x = JNIHandles::resolve(x_h); // 新值
oop e = JNIHandles