【JAVA笔记——道】JAVA原子性解决方案java.util.concurrent.atomic

深入理解Java.util.concurrent.atomic中的原子操作原理
本文详细解析了Java.util.concurrent.atomic包下的原子性实现类,如AtomicBoolean,AtomicInt,AtomicLong等,重点阐述了这些类在多线程环境下如何实现数据的原子操作,以及与并发控制语句的区别和性能优势。通过分析内部实现细节,包括Unsafe类的使用和内存操作的原子性保障,帮助读者理解如何在高并发场景下有效管理共享数据。

java.util.concurrent是jdk提供在多线程下的原子性解决方案,java.util.concurrent下主要是常用数据结构的原子性实现类,java.util.concurrent.atomic是基础数据类型的原子性实现类
推荐先看:如何对JAVA进行内存操作 sun.misc.Unsafe类

AtomicBoolean

顾名思义,该类其实是一个原子布尔类,定义域如下:

    private static final long serialVersionUID = 4654671469794556979L;
    private static final Unsafe unsafe = Unsafe.getUnsafe();
    private static final long valueOffset;

    static {
        try {
        //返回定义域在内存中的偏移量
            valueOffset = unsafe.objectFieldOffset(AtomicBoolean.class.getDeclaredField("value"));
        } catch (Exception ex) { throw new Error(ex); }
    }

    private volatile int value;

在该类中,value是对核心数据boolean的存储,unsafe以及valueOffset都是用于实现value操作过程中的原子性。并发性的控制主要通过Unsafe进行操作。

//正常赋值
public final void set(boolean newValue) {
    value = newValue ? 1 : 0;
}

//懒加载,内存操作,不进行store load
public final void lazySet(boolean newValue) {
    int v = newValue ? 1 : 0;
    unsafe.putOrderedInt(this, valueOffset, v);
}

//取值后更新
public final boolean getAndSet(boolean newValue) {
    boolean prev;
    do {
        prev = get();
    } while (!compareAndSet(prev, newValue));
    return prev;
}
//if(expect == update) update();
public final boolean compareAndSet(boolean expect, boolean update) {
    int e = expect ? 1 : 0;
    int u = update ? 1 : 0;
    return unsafe.compareAndSwapInt(this, valueOffset, e, u);
}

“`
与之相似的还有AtomicInt,AtomicLong等,实现方式没有太大的区别。

相对与并发控制语句,原子操作实际上进行的是内存级别的乐观锁控制,因此,性能上要比synchronized性能高出300倍以上

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值