原子类型AtomicLong用法探究

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。

你可能感兴趣的:(软件开发,AtomicLong,LongAddr,Android原子类型,多线程AtomicLong,大牛直播SDK)