AtomicLong探究
AtomicLong 是 Java 提供的一个原子长整型类,提供了对长整型数据的原子性操作。在多线程环境下,AtomicLong 可以确保对长整型数据的操作是线程安全的。
在 Android 中,AtomicLong 的使用方法和功能与标准 Java 中的 AtomicLong 相同。你可以通过以下方式创建一个 AtomicLong 对象:
AtomicLong atomicLong = new AtomicLong(initialValue);上述代码,initialValue 是 AtomicLong 对象的初始值。
一旦创建了 AtomicLong 对象,你可以使用以下方法对其进行操作:
get():获取当前的值。set(long newValue):设置新的值。getAndSet(long newValue):获取当前的值并设置新的值。compareAndSet(long expect, long update):如果当前值等于expect,则将值设置为update。getAndIncrement():获取当前的值并增加 1。getAndDecrement():获取当前的值并减少 1。incrementAndGet():增加当前的值并获取新的值。decrementAndGet():减少当前的值并获取新的值。
这些方法都提供了对 AtomicLong 对象的原子性操作,确保在多线程环境下的数据安全性。
AtomicLong 的 Android 代码示例:
import java.util.concurrent.atomic.AtomicLong;
public class MyAtomicLong {
private static AtomicLong counter = new AtomicLong(0);
public static void main(String[] args) {
// 创建两个线程同时执行操作
Thread thread1 = new Thread(new MyRunnable());
Thread thread2 = new Thread(new MyRunnable());
thread1.start();
thread2.start();
}
private static class MyRunnable implements Runnable {
@Override
public void run() {
// 每次递增 1
long value = counter.incrementAndGet();
System.out.println("Value: " + value);
}
}
}在这个示例中,我们创建了一个 AtomicLong 对象 counter,并使用 incrementAndGet() 方法对其进行递增操作。然后,我们创建两个线程并启动它们,同时对 counter 进行操作。由于 AtomicLong 的原子性操作,我们可以在多线程环境下安全地递增 counter,避免了竞态条件的问题。
AtomicLong和LongAddr区别
AtomicLong 是基于 CAS 方式自旋更新的;LongAdder 是把 value 分成若干cell,并发量低的时候,直接 CAS 更新值,成功即结束。
并发量高的情况,CAS更新某个cell值和需要时对cell数据扩容,成功结束;更新失败自旋 CAS 更新 cell值。
取值的时候,调用 sum() 方法进行每个cell累加。 AtomicLong 包含有原子性的读、写结合的api;LongAdder 没有原子性的读、写结合的api,能保证结果最终一致性。 低并发场景AtomicLong 和 LongAdder 性能相似,高并发场景 LongAdder 性能优于 AtomicLong。










