美文网首页工作生活
java中的CAS是如何保证线程安全的

java中的CAS是如何保证线程安全的

作者: springczg | 来源:发表于2019-07-02 14:47 被阅读0次

    java中的CAS是如何保证线程安全的

    现在有一个线程共享的变量i=0,让两个线程分别对i进行i++操作10次,那么我们最后得到的结果是20吗?答案肯定是小于20的;

    第一种情况(线程不安全):线程1读取了i=0;线程2读取了i=0之后线程2被阻塞了;线程1:i++=1; 现在i=1;线程2继续执行,然后线程2执行i++操作,也是1;连个线程操作值均为1;

    先看看这几个参数 this 当前对象,this对象value成员变量在内存中的偏移量。我们可以简单地把valueOffset理解为value变量的内存地址,var1 旧得期望值,var2 需要更新的值;  当且仅当 , 内存值和旧的期望值相等时,将valueOffset 更新为var2。

    example:

    1. 例如变量 int i=1; 

    2. 内存中的值为1(valueOffset=1),旧的预期值为var1=1;i++为var2=2 是需要更新的值,

    3. 线程1进行操作将要更新操作valueOffset=2;此时线程2进行操作的时候,valueOffset=2,而线程2读取到的旧的预期值还是1,那么会更新失败,

    4. 线程2重新开始获取值(自旋操作),进行更新操作,此时valueOffset=3;

    CAS有个问题,1. 在线程比较多,并发比较大的情况下,会一直自旋,会消耗很多的cpu资源; 2. ABA问题  解决ABA问题可以添加版本号,或者可以用AtomicStaampedRefence;

    相关文章

      网友评论

        本文标题:java中的CAS是如何保证线程安全的

        本文链接:https://www.haomeiwen.com/subject/gwyzcctx.html