AtomicInteger,AtomicLong等,这里用volatile修饰的成员变量value,为啥后面又要在静态代码块里面,去通过反射获取转换一下,没看懂。
private static final Unsafe unsafe = Unsafe.getUnsafe();
private static final long valueOffset;
private volatile int value;
static{
try{
valueOffset = unsafe.objectFieldOffset(AtomicInteger.class.getDeclaredField("value"));
}catch(Exception ex){
throw new Error(ex);
}
}
AtomicXXX
类底层并不仅通过 volatile 关键字修改保证其多线程下的安全性,
这里的静态代码块就是读取就是通过偏移量使用 CAS 操作从硬件层面保证读取值的是实时且有效。
如果觉得我的回答有用的话,请点个采纳