AtomicIntegerArray提供线程安全的原子操作,支持数组元素的高效并发修改,适用于多线程计数等场景。

在Java中,AtomicIntegerArray 提供了一种线程安全的方式来操作整型数组中的单个元素,确保对数组元素的读取、写入和更新操作是原子的。它属于 java.util.concurrent.atomic 包,适用于多线程环境下需要频繁修改数组元素但又不想使用 synchronized 的场景。
创建 AtomicIntegerArray 实例
可以通过以下两种方式创建 AtomicIntegerArray:
传入一个 int 数组,构造函数会复制该数组的内容,避免外部修改影响内部数据 指定数组长度,初始化为默认值 0
// 方式1:基于现有数组int[] arr = {1, 2, 3};AtomicIntegerArray atomicArray = new AtomicIntegerArray(arr);// 方式2:指定长度AtomicIntegerArray atomicArray2 = new AtomicIntegerArray(10); // 长度为10,初始值全为0
常用原子操作方法
AtomicIntegerArray 提供了一系列以原子方式操作指定索引元素的方法:
get(int i):获取索引 i 处的当前值 set(int i, int newValue):设置索引 i 处的值 lazySet(int i, int newValue):延迟设置值,性能更好但可见性稍弱 compareAndSet(int i, int expect, int update):CAS 操作,只有当当前值等于 expect 时才更新为 update incrementAndGet(int i):将索引 i 处的值加1并返回新值 decrementAndGet(int i):减1并返回新值 addAndGet(int i, int delta):增加指定增量并返回结果
AtomicIntegerArray arr = new AtomicIntegerArray(2);arr.set(0, 10);arr.incrementAndGet(0); // 返回11,arr[0] 变为11arr.compareAndSet(1, 0, 5); // 若 arr[1]==0,则设为5arr.addAndGet(0, 3); // 返回14,arr[0] 变为14
实际应用场景示例
比如统计多个线程对不同资源的访问次数,可以用 AtomicIntegerArray 作为计数器数组:
AI TransPDF
高效准确地将PDF文档翻译成多种语言的AI智能PDF文档翻译工具
231 查看详情
立即学习“Java免费学习笔记(深入)”;
AtomicIntegerArray counters = new AtomicIntegerArray(3);Runnable task = () -> { for (int i = 0; i < 1000; i++) { int idx = ThreadLocalRandom.current().nextInt(3); counters.incrementAndGet(idx); }};// 启动多个线程Thread t1 = new Thread(task);Thread t2 = new Thread(task);t1.start(); t2.start();t1.join(); t2.join();System.out.println("Counter 0: " + counters.get(0));System.out.println("Counter 1: " + counters.get(1));System.out.println("Counter 2: " + counters.get(2));
这个例子中,多个线程并发地对数组元素进行自增操作,无需额外同步机制,保证了线程安全。
基本上就这些。AtomicIntegerArray 不是对整个数组操作原子化,而是保证每个元素的单独操作是原子的,适合用于状态标志、计数器数组等高并发场景。不复杂但容易忽略的是:它持有的是原始数组的副本,后续修改原数组不会影响它。
以上就是Java中如何通过AtomicIntegerArray操作数组原子元素的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/717697.html
微信扫一扫
支付宝扫一扫