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


    简介

    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());
    		}
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
  • 相关阅读:
    【电源专题】LDO的电源抑制比(PSRR)
    开发记录【1】
    集美大学-浙大版《C语言程序设计实验与习题指导(第3版)》
    深入底层学git:目录中包含的秘密
    计算机毕业设计之java+ssm的图书借阅系统
    线段树模板
    后端项目连接数据库-添加MyBatis依赖并检测是否成功
    [S-Clustr]利用环形网络高匿名性控制骇客设备
    《高性能网站建设进阶指南》阅读笔记
    基于go-micro微服务的实战-注册成功推送Rabbitmq队列,邮件服务异步发送邮件(七)
  • 原文地址:https://blog.csdn.net/u010804417/article/details/126767117