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,因为它是非阻塞的,允许您缓存任何类型的数据. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |