码迷,mamicode.com
首页 > 编程语言 > 详细

Java并发编程-CAS

时间:2015-06-02 10:41:45      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:

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/

Java并发编程-CAS

标签:

原文地址:http://www.cnblogs.com/tangyanbo/p/4545599.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!