并发实战——原子类AtomicReference及底层源码CompareAndSwapObject分析

本文深入探讨了Java并发编程中的AtomicReference原子类,分析了其核心方法compareAndSwapObject的源码,揭示了其依赖于CPU的cmpxchg指令实现原子性。通过查看OpenJDK源码,理解了CAS在多处理器环境下的实现,并探讨了其在保证并发操作原子性中的关键作用。

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

本文内容:

  • 分析原子类AtomicReference
  • 分析源码

AtomicReference中

public final boolean compareAndSet(V expect, V update) {
        return unsafe.compareAndSwapObject(this, valueOffset, expect, update);
    }
public final V getAndSet(V newValue) {
        return (V)unsafe.getAndSetObject(this, valueOffset, newValue);
    }


    public final Object getAndSetObject(Object var1, long var2, Object var4) {
        Object var5;
        do {
            var5 = this.getObjectVolatile(var1, var2);
        } while(!this.compareAndSwapObject(var1, var2, var5, var4));

        return var5;
    }

compareAndSwapObject 源码探析

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

可以看到声明的是native方法,意味着该方法使用更底层的代码(cpp)实现的,需要下载openjdk源码才可以看到。下面开始简要地介绍下寻找源码的过程。


下载好openjdk源码后,将其导入到idea里该project的lib中,方便全局查找。

参照native实现规则,可以猜测javah工具生成的cpp头文件。

这里写图片描述

UNSAFE_ENTRY(jboolean, Unsafe_CompareAndSwapObject(JNIEnv *env, jobject unsafe, jobject obj, jlong offset, jobject e_h, jobject x_h))
  UnsafeWrapper("Unsafe_CompareAndSwapObject");
  oop x = JNIHandles::resolve(x_h); // 新值
  oop e = JNIHandles
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值