AtomicInteger——Java中的多线程共享原子计数器

AtomicInteger

  • 简介
  • AtomicInteger拥有的方法
    • getAndIncrement()
    • incrementAndGet()
    • get()
  • AtomicInteger在Java多线程中的使用方法
    • 多线程借助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());
		}
	}
}

你可能感兴趣的:(编程语言,java,多线程,原子计数器,AtomicInteger)