一、AtomicInteger定义
-
AtomicInteger类是系统底层保护的int类型,通过对int类型的数据进行封装,提供执行方法的控制进行值的原子操作,但AtomicInteger ≠ Integer。 -
AtomicInteger是一个提供原子操作的Integer类,通过线程安全的方式操作加减。
从JAVA 1.5开始,AtomicInteger 属于java.util.concurrent.atomic 包下的一个类。
二、AtomicInteger使用场景
-
AtomicInteger提供原子操作来进行Integer的使用,适合高并发情况下的使用。 -
foreach作循环的时候需要对应参数进行自增或者自减操作。
三、AtomicInteger作用
分析普通Java的运算操作:
Java中的运算操作在多线程是线程不安全的。比如i++解析为i=i+1,Java程序会把算式分为3个操作,获取值,计算值,赋予值,i++这个操作不具备原子性,多线程并发共享变量时必然会出现问题。
原子性:
指的就是一个操作是不可中断,即使有多个线程执行,一个操作开始也不会受其他线程影响,即可以理解为线程的最小执行单元,不可被分割。
一个线程计算出值后,还未重新给变量赋值,另一个线程来读取到这个值,就会造成线程不安全的问题,有时候需要通过加锁的方式去保证线程安全,但是加锁对性能会有很大的影响。
-
AtomicInteger是一个提供原子操作的Integer类,使用CAS+volatile实来现线程安全的数值操作。 -
因为
volatile禁止了jvm的排序优化,所以它不适合在并发量小的时候使用,只适合在一些高并发程序中使用
Java中的AtomicInteger:原子性操作与线程安全
AtomicInteger是Java并发包下的一个类,提供线程安全的int值操作,基于CAS和volatile实现原子性,常用于高并发场景下的计数或同步。它的使用避免了传统的加锁机制,提高了性能,但在并发量小时,其开销可能大于普通的同步控制。
480

被折叠的 条评论
为什么被折叠?



