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。