用volatile修饰的成员变量value,为啥后面又要在静态代码块里面,去通过反射获取转换一下

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 操作从硬件层面保证读取值的是实时且有效。
如果觉得我的回答有用的话,请点个采纳