Java中CompareAndSwap(CAS)compareAndSwapInt 一些理解,随手记录下

最近在瞅ConcurrentHashMap源码, CAS的这个方法compareAndSwapInt,有些不是很理解.

虽然知道cas的原理,但是对于这个方法还是比较迷惑,这里随手记录下,查了资料以后的理解。

// 最底层是native方法,那就是C语言实现的,目前没看过C源码,这个坟值得一挖.
public final native boolean compareAndSwapInt(Object var1, long var2, int var4, int var5);

// 使用就个样子
sun.misc.Unsafe U = sun.misc.Unsafe.getUnsafe();
boolean flag = sun.misc.Unsafe.compareAndSwapInt(object, offset, expect, update);

解释一波:
这里共有4个参数
(1)object:就是将要修改的值的对象.
(2)offect:对象在内存中偏移量为offset处的值,就是要修改的数据的值在内存中的偏移量,
结合object + offect找到要修改的值.
(3)expect:期望内存中的值,就是拿这个值和 object + offect值进行比较;如果相同则修改,返回true,否则返回false,等下次修改.
(4)update:如果上一步对比相等,则将这个值赋值给 object + offect值,然后返回true。

大致理解就这样,不知道解释的对不对,后面挖坟回来再补。先记下来。

你可能感兴趣的:(学习,技术,编程学习,java,object)