Java并发编程原子类实现-AtomicInteger incrementAndGet方法实现

本文探讨了Java并发编程中AtomicInteger的incrementAndGet方法的实现,通过Unsafe类和内存屏障确保并发场景下的原子性。文章解释了Unsafe类的背景、不安全性以及其在Java并发库中的应用。同时,详细阐述了volatile如何通过内存屏障保证可见性,以及内存屏障的作用和分类。最后,讨论了volatile与内存屏障的关系,以及它们在final域中的应用。
摘要由CSDN通过智能技术生成

背景,多个生产者一个消费者,实现生产者生产数据按产生顺序加上编号
简单应用如下,子线程进行原子增

public class Producer implements Runnable {
   
    private static AtomicInteger  count= new AtomicInteger();
      public void run() {
         String data = null;
        count.incrementAndGet()
        data = "data:" + count.incrementAndGet();
        System.out.println("将数据:" + data + "放入队列...");
    }
    }

执行:

        // 声明一个容量为10的缓存队列
        BlockingQueue<String> queue = new LinkedBlockingQueue<String>(10);

        Producer producer1 = new Producer(queue);
        Producer producer2 = new Producer(queue);
        Producer producer3 = new Producer(queue);
        Consumer consumer = new Consumer(queue);

        // 借助Executors
        ExecutorService service = Executors.newCachedThreadPool();
        // 启动线程
        service.execute(producer1);
        service.execute(producer2);
        service.execute(producer3);
        service.execute(consumer);

运行结果如下:

这里写图片描述

在多线程的场景即可实现原子加

打开incrementAndGet调用链,调用方法如下:



    public class Atom
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值