加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

java – 以原子方式更新多个volatile和j.u.c.atomic变量

发布时间:2020-12-15 04:44:47 所属栏目:Java 来源:网络整理
导读:为了原子地更新两个或更多的volatile变量,是否需要通过lock with synchronized,reentrantReadWriteLock等来保护它? 即 volatile int vVar1,vVar1; // or AtomicInteger/*** Needs to be updated atomically ***/void atomicUpdate(int var1,int var2){ vVar
为了原子地更新两个或更多的volatile变量,是否需要通过lock with synchronized,reentrantReadWriteLock等来保护它?

volatile int vVar1,vVar1; // or AtomicInteger

/*** Needs to be updated atomically ***/
void atomicUpdate(int var1,int var2){
  vVar1 = var1;
  vVar2 = var2;
}

java.util.concurrent.atomic变量的代码相同.

解决方法

如果需要以原子方式分配两个值,则将volatile int转换为AtomicInteger将无法解决您的竞争条件问题.

要解决您的问题,您基本上有两个选择:

>使方法更新变量同步(也许是读取这些变量的方法)
>为两个变量创建一个包装器,并利用赋值是一个原子操作的事实

选项2的示例:

volatile Vars vars;
void atomicUpdate(int var1,int var2) {
    vars = new Vars(var1,var2);
}

public static Vars {
    private int vVar1;  // volatile if they need to be modified
    private int vVar2;
}

我很喜欢选项2,因为它是非阻塞的,允许您缓存任何类型的数据.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读