AtomicInteger类是系统底层保护的int类型,通过对int类型的数据进行封装,提供执行方法的控制进行值的原子操作。AtomicInteger它不能当作Integer来使用
从JAVA 1.5开始,AtomicInteger 属于java.util.concurrent.atomic 包下的一个类
。
在Java中的运算操作,例如自增或自减,在多线程环境下就是线程不安全的。num++解析为num=num+1,Java程序会把算式分为3个操作,获取值,计算值,赋予值,明显,这个操作不具备原子性,多线程并发共享这个变量时必然会出现问题。
一个线程计算出值后,还未重新给变量赋值,另一个线程有来读取到这个值,就会造成线程不安全的问题。
想让线程安全,往往可能需要通过加锁的方式去保证线程安全,但是,加锁对性能会有很大的影响。
而AtomicInteger原子类型就是让程序在不加锁的时候也能保障线程安全,案例如下:
static int b =0;
public static void main(String[] args) throws InterruptedException {
AtomicInteger a = new AtomicInteger(0);
Thread t1 = new Thread(new Runnable() {
@Override
public void run() {
for (int i = 0; i < 10000; i++) {
a.incrementAndGet();
b++;
}
}
});
t1.start();
Thread t2 = new Thread(new Runnable() {
@Override
public void run() {
for (int i = 0; i < 10000; i++) {
a.incrementAndGet();
b++;
}
}
});
t2.start();
Thread.sleep(1000);
System.out.println("a="+a);
System.out.println("b="+b);
}
输出结果:
根据结果可见,使用AtomicInteger在多线程进行自增运算的时候,是线程安全的,而普通的int在自增的时候则是线程不安全的。
incrementAndGet()方法,是AtomicInteger的自增方法,会让AtomicInteger的值+1。