AtomicInteger怎么实现的线程安全

本文深入解析了Java中的AtomicInteger类的addAndGet方法,该方法通过Unsafe类实现线程安全的整数加法。Unsafe类直接操作内存,getAndAddInt方法使用循环和CAS(Compare and Swap)操作确保并发环境下数据的一致性。在多线程环境中,当多个线程尝试更新AtomicInteger时,只有一个线程能成功修改值,其他线程会重试,直到更新成功,确保了线程安全。

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

这里我们看下addAndGet方法

上源码

public final int addAndGet(int var1) {
    return unsafe.getAndAddInt(this, valueOffset, var1) + var1;
}

调用的Unsafe类,这个类是直接操作内存的。继续跟进Unsafe.getAndSetInt

public final int getAndAddInt(Object var1, long var2, int var4) {
    int var5;
    do {
        var5 = this.getIntVolatile(var1, var2);
    } while(!this.compareAndSwapInt(var1, var2, var5, var5 + var4));

    return var5;
}

这个方法就是为什么保证线程安全。

首先第一参数是AtomicInteger值本身,第二个参数是内存中的偏移量,第三个参数是addAndGet传入的值,也就是要加的数。

循环去拿对象本身在内存偏移量后的值,循环条件是compareAndSwapInt返回false,如果为true则跳出循环。

compareAndSwapInt是CAS 比较&交换,如果偏移量的值跟取到的var5值相等,那么就var5 + var4替换var1,这步是原子性的。

当多个线程同时进入var5 = this.getIntVolatile(var1, var2);,都拿到了相同的偏移量后的值,但是compareAndSwapInt是原子性的,一定会有一个线程先改变了偏移量后的值,那么其他线程就会compareAndSwapInt返回false,继续去拿修改后的值,然后继续compareAndSwapInt,直到它执行一次循环没有其他线程改变这个值,那么才会修改成功。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值