原子类型AtomicLong用法探究

简介: AtomicLong 是 Java 提供的一个原子长整型类,提供了对长整型数据的原子性操作。在多线程环境下,AtomicLong 可以确保对长整型数据的操作是线程安全的。

AtomicLong探究

AtomicLong 是 Java 提供的一个原子长整型类,提供了对长整型数据的原子性操作。在多线程环境下,AtomicLong 可以确保对长整型数据的操作是线程安全的。


在 Android 中,AtomicLong 的使用方法和功能与标准 Java 中的 AtomicLong 相同。你可以通过以下方式创建一个 AtomicLong 对象:

AtomicLong atomicLong = new AtomicLong(initialValue);

上述代码,initialValueAtomicLong 对象的初始值。


一旦创建了 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。

相关文章
|
5月前
|
存储 缓存 算法
Java并发基础:原子类之AtomicMarkableReference全面解析
AtomicMarkableReference类能够确保引用和布尔标记的原子性更新,有效避免了多线程环境下的竞态条件,其提供的方法可以轻松地实现基于条件的原子性操作,提高了程序的并发安全性和可靠性。
Java并发基础:原子类之AtomicMarkableReference全面解析
|
4月前
|
缓存 安全 Java
《volatile使用与学习总结:》多层面分析学习java关键字--volatile
《volatile使用与学习总结:》多层面分析学习java关键字--volatile
28 0
|
1月前
|
存储 编译器 程序员
为什么不应该使用"volatile"类型的类 【ChatGPT】
为什么不应该使用"volatile"类型的类 【ChatGPT】
|
3月前
|
缓存 安全 Java
Java面试题:解释volatile关键字的作用,以及它如何保证内存的可见性
Java面试题:解释volatile关键字的作用,以及它如何保证内存的可见性
61 4
|
3月前
|
安全 Java
Java面试题:解释synchronized关键字在Java内存模型中的语义
Java面试题:解释synchronized关键字在Java内存模型中的语义
41 1
|
5月前
|
缓存 安全 算法
Java并发基础:原子类之AtomicInteger全面解析
【2月更文挑战第2天】AtomicInteger类提供了线程安全的整数操作,它通过利用底层硬件的原子性指令,能够在多线程环境中高效地实现整数的无锁更新,避免了传统同步机制带来的性能开销,在高并发场景下成为计数器可大幅提高程序的执行效率,同时又保证了数据一致性。
191 16
Java并发基础:原子类之AtomicInteger全面解析
|
5月前
|
存储 算法 安全
Java并发基础:原子类之AtomicBoolean全面解析
【2月更文挑战第1天】 AtomicBoolean类优点在于能够确保布尔值在多线程环境下的原子性操作,避免了繁琐的同步措施,它提供了高效的非阻塞算法实现,可以大大提成程序的并发性能,AtomicBoolean的API设计非常简单易用。
185 3
Java并发基础:原子类之AtomicBoolean全面解析
|
5月前
|
Java
多线程与并发编程:解释什么是死锁,并给出一个在Java中发生死锁的例子。描述一下Java中的volatile关键字的作用,以及它与synchronized的区别。
多线程与并发编程:解释什么是死锁,并给出一个在Java中发生死锁的例子。描述一下Java中的volatile关键字的作用,以及它与synchronized的区别。
41 0
|
12月前
|
存储 算法 程序员
[笔记]C++并发编程实战 《五》C++内存模型和原子类型操作
[笔记]C++并发编程实战 《五》C++内存模型和原子类型操作
|
算法 Java
第二季:3原子类AtomicInteger的ABA问题谈谈?原子更新引用知道吗?【Java面试题】
第二季:3原子类AtomicInteger的ABA问题谈谈?原子更新引用知道吗?【Java面试题】
97 0