栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

AtomicInteger用于异步统计的原子类

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

AtomicInteger用于异步统计的原子类

AtomicInteger用于异步统计的原子类
在异步操作中进行自增长统计理论上是可以用全局变量int类型统计的,但线程数多了,数据就会出错,因为count++不是原子性的。而且全局变量存储在全局数据区中,全局变量的生命期和主程序一样,随程序的销毁而销毁,占用空间多。
使用AtomicInteger就能保证数据的原子性,特别是在高度并发竞争情形下,AtomicInteger非常适用。
public class AutomicIntegerTest implements Runnable {

        static AtomicInteger atomicInteger = new AtomicInteger(0);

        static int commonInteger = 0;

        public void addAtomicInteger() {
            atomicInteger.getAndIncrement();
        }

        public void addCommonInteger() {
            commonInteger++;
        }

        @Override
        public void run() {
            //可以调大10000看效果更明显
            for (int i = 0; i < 100000; i++) {
                addAtomicInteger();
                addCommonInteger();
            }
        }

        public static void main(String[] args) throws InterruptedException {
            AutomicIntegerTest atomicIntegerTest = new  AutomicIntegerTest();
            Thread thread1 = new Thread(atomicIntegerTest);
            Thread thread2 = new Thread(atomicIntegerTest);
            thread1.start();
            thread2.start();
            //join()方法是为了让main主线程等待thread1、thread2两个子线程执行完毕
            thread1.join();
            thread2.join();
            System.out.println("AtomicInteger add result = " + atomicInteger.get());
            System.out.println("CommonInteger add result = " + commonInteger);
        }
    }

循环1w次以上差异明显

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/705265.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号