Java中的CAS操作

CAS(Compare and Swap)是JDK提供的非阻塞原子性操作,通过Unsafe类实现。它涉及三个操作数:内存位置、偏移量和新旧值。然而,CAS存在ABA问题,即值在修改后又变回原来的值,导致错误判断。为解决此问题,JDK提供了AtomicStampedReference类,使用时间戳来防止ABA问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CAS(Compare and Swap),JDK提供的非阻塞原子性操作,通过硬件保证了比较-更新操作的原子性。
JDK里面的Unsafe类提供了一系列compareAndSwap*方法:

public final native boolean compareAndSwapObject(Object var1, long var2, Object var4, Object var5);

    public final native boolean compareAndSwapInt(Object var1, long var2, int var4, int var5);

    public final native boolean compareAndSwapLong(Object var1, long var2, long var4, long var6);

CAS有四个操作数,分别为:对象内存位置、对象中的变量的偏移量、变量预期值和新的值。

ABA问题

线程1首先获取变量X的值为A,然后使用CAS操作修改为B。在执行CAS之前,线程2修改了X的值为B,又改为A。所以线程1执行CAS时X的值为A,但这个A以及不是线程1获取时的A了。
ABA问题
ABA问题的产生是因为变量的状态值发生了环形转换,A -> B -> A。
如果变量的值只能朝着一个方向转换,A -> B -> C,不能构成环形,就不会存在问题。
JDK中的AtomicStampedReference类给每个变量的状态值都配备了一个时间戳,从而避免了ABA问题。

public boolean compareAndSet(V   expectedReference,
                                 V   newReference,
                                 int expectedStamp,
                                 int newStamp) {
        Pair<V> current = pair;
        return
            expectedReference == current.reference &&
            expectedStamp == current.stamp &&
            ((newReference == current.reference &&
              newStamp == current.stamp) ||
             casPair(current, Pair.of(newReference, newStamp)));
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值