AtomicInteger
简介
AtomicInteger是线程安全的,即使不使用synchronized关键字也能保证其是线程安全的,主要用于多线程间共享计数。比如多个线程从列表中依次读取数据,使用AtomicInteger来计数,每次取第AtomicInteger个。而且由于AtomicInteger由硬件提供原子操作指令实现,在非激烈竞争的情况下,开销更小,速度更快。
AtomicInteger拥有的方法
getAndIncrement()
先获取当前值,再加1。相当于 getAndAdd(1).
incrementAndGet()
先加1,再获取当前值。相当于 addAndGet(1).
get()
atomicInteger.get()
获取当前AtomicInteger对象的计数值,以int类型返回。
AtomicInteger在Java多线程中的使用方法
通过将要借助AtomicInteger来实现的各功能,封装到一个自定义类中的各个对应方法,使用时通过创建自定义类的对象来调用各个对应方法来实现。
多线程借助AtomicInteger共享计数
如果多线程想要借助AtomicInteger共享计数,需要在主线程(main)中创建并初始化AtomicInteger对象,再通过构造函数的引用传递才能实现多线程共享计数;之所以不能在每个线程的构造函数中分别初始化是因为——每个构造函数都会新建一个线程,若在构造函数中初始化AtomicInteger,相当于每个线程中分别创建了一个计数,而无法通过主线程在多个线程中共享AtomicInteger变量从而计数,如下方代码所示。
public class TestThread extends Thread implements Runnable {
AtomicInteger counterAtomicInteger;
public static void main(String[] args) {
// TODO Auto-generated method stub
//使用此种方式,运行结果顺序递增,但是两个线程分别计数
TestThread thread1 = new TestThread();
TestThread thread2 = new TestThread();
thread1.start();
thread2.start();
//使用此种方式,运行结果不一定顺序递增,但是统一计数
AtomicInteger testAtomicInteger = new AtomicInteger(0);
TestThread thread1 = new TestThread(testAtomicInteger);
TestThread thread2 = new TestThread(testAtomicInteger);
thread1.start();
thread2.start();
}
public TestThread() {
// TODO Auto-generated constructor stub
counterAtomicInteger = new AtomicInteger(0);
}
public TestThread(int InitialValue) {
// TODO Auto-generated constructor stub
counterAtomicInteger = new AtomicInteger(InitialValue);
}
public TestThread(AtomicInteger counterAtomicInteger) {
// TODO Auto-generated constructor stub
this.counterAtomicInteger = counterAtomicInteger;
}
@Override
public void run() {
// TODO Auto-generated method stub
// super.run();//教学视频中删掉了本句,原因不明
for (int i = 0; i < 10; i++) {
System.out.println(counterAtomicInteger.getAndIncrement());
}
}
}