标签:
CAS(Compare and swap)比较和替换是设计并发算法时用到的一种技术。简单来说,比较和替换是使用一个期望值和一个变量的当前值进行比较,如果当前变量的值与我们期望的值相等,就使用一个新值替换当前变量的值
Unsafe用法:
作用,如果当前值和期望值相等,则将当前值更新为新的值X,并返回true
否则什么都不做,返回false
return unsafe.compareAndSwapInt(this, stateOffset, expect, update);/** * Atomically update Java variable to <tt>x</tt> if it is currently * holding <tt>expected</tt>. * @return <tt>true</tt> if successful */ public final native boolean compareAndSwapInt(Object o, long offset, int expected, int x);
参考文章:
http://ifeve.com/compare-and-swap/
标签:
原文地址:http://www.cnblogs.com/tangyanbo/p/4545599.html