zoukankan      html  css  js  c++  java
  • sun.misc.Unsafe CAS

    日常写代码很少直接使用到Unsafe,时常看jdk的时候,遇到这个使用场景。刚挑选了一个比较熟悉的CAS来做一个api使用测试。

    public class UnsafeTest {
    
        private String name = "a";
    
        private String addr = "b";
    
        private int age = 11;
    
        private int id = 2;
    
        public static void main(String[] args) throws NoSuchFieldException, IllegalAccessException {
    		//Unsafe unsafe = Unsafe.getUnsafe();  //不允许外部使用,会抛异常
    
            Field theUnsafeInstance = Unsafe.class.getDeclaredField("theUnsafe");
            theUnsafeInstance.setAccessible(true);
            Unsafe unsafe =  (Unsafe) theUnsafeInstance.get(Unsafe.class);
    
            long ageOffset = unsafe.objectFieldOffset
                    (UnsafeTest.class.getDeclaredField("age"));
    
            UnsafeTest unsafeTest = new UnsafeTest();
    
            System.out.println(unsafe.compareAndSwapInt(unsafeTest,ageOffset,11,22));
            System.out.println(unsafeTest.age);
        }
    }
    

    由于Unsafe.getUnsafe()是不允许外部使用的,会抛出java.lang.SecurityException: Unsafe异常。所以利用反射获取Unsafe实例。

    compareAndSwapInt(Object var1, long var2, int var4, int var5)有四个参数。

    • 第一个是被修改的对象
    • 第三个是被修改的属性当前的期望值
    • 第四个是计划要修改的值

    其实就是,当var1对象的某个属性,值为var4,就修改为var5.这里说了,是某个属性,而第二个参数则是用来标注所需要修改的属性的offset了。

    通俗来讲,就是offset偏移量,就等于是某个字段的坐标位置(指针)。

  • 相关阅读:
    (转)简洁常用的栏目切换js.可以直接使用
    (转)MVC3+EF4.1学习系列(十)MVC+EF处理树形结构
    欧拉图
    SPFA算法——最短路径
    uva 10608 FRIENDS
    scau 1077 韩信点兵
    最短路径的几种算法的路径问题(floy , dij , spfa)
    最大流(BFS)
    hdu 3459 Flow Problem
    并查集
  • 原文地址:https://www.cnblogs.com/coderzl/p/7523908.html
Copyright © 2011-2022 走看看