微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – 大于比较和交换

正如标题所示,我正在寻找一种比较和交换实现,但是比较大:
if(newValue > oldValue) {
    oldValue = newValue;
}

其中oldValue是一些全局共享状态,并且newValue对每个线程都是私有的,而不需要这样做:

synchronized(locker) {
    if(newValue > oldValue) {
        oldValue = newValue;
    }       
}

因为我想要一个非阻塞的解决方案.从研究其他非阻塞操作的源代码,我已经提出了这一点(假设值是整数):

AtomicInteger oldValue; // shared global variable

...

public boolean GreaterThanCAS(int newValue) {

    while(true) {
        int local = oldValue;
        if(local == oldValue) {
            if(newValue > local) {
                 if(oldValue.compareAndSwap(local,newValue) {
                     return true;  // swap successful
                 } // else keep looping
            } else {
                 return false; // swap Failed
            }
        } // else keep looping
    }
}

当// else保持循环发生时,这意味着另一个线程在此期间更改了oldValue,因此我需要循环并重试.

这个实现是否正确(线程安全)?

解决方法

如果没有线程减少AtomicInteger的值,我认为您的实现没有问题.如果他们这样做,您的代码是可以竞争的条件.

请注意,代码可以简化如下:

public boolean GreaterThanCAS(int newValue) {
    while(true) {
        int local = oldValue.get();
        if(newValue <= local) {
             return false; // swap Failed
        }
        if(oldValue.compareAndSwap(local,newValue)) {
             return true;  // swap successful
        }
        // keep trying
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


应用场景 C端用户提交工单、工单创建完成之后、会发布一条工单创建完成的消息事件(异步消息)、MQ消费者收到消息之后、会通知各处理器处理该消息、各处理器处理完后都会发布一条将该工单写入搜索引擎的消息、最终该工单出现在搜索引擎、被工单处理人检索和处理。 事故异常体现 1、异常体现 从工单的流转记录发现、
线程类,设置有一个公共资源 package cn.org.chris.concurrent; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; /** * @Descrip
Java中的数字(带有0前缀和字符串)
在Java 9中使用JLink的目的是什么?
Java Stream API Filter(过滤器)
在Java中找到正数和负数数组元素的数量
Java 9中JShell中的不同启动脚本是什么?
使用Java的位填充错误检测技术
java中string是什么
如何使用Java中的JSON-lib API将Map转换为JSON对象?