作者简介:笔名seaboat,擅长工程算法、人工智能算法、自然语言处理、计算机视觉、架构、分布式、高并发、大数据和搜索引擎等方面的技术,大多数编程语言都会使用,但更擅长Java、Python和C++。平时喜欢看书写作、运动、画画。崇尚技术自由,崇尚思想自由。出版书籍:《Tomcat内核设计剖析》、《图解数据结构与算法》、《图解Java并发原理》、《人工智能原理科普》。
原子数组
JDK提供了对数组原子操作的类,当然我们可以通过synchronized互斥锁的机制来实现对数组的原子操作,但如果想通过更高效的CAS机制实现原子更新的话就可以使用原子数组。如下图所示,对数组中的元素提供了CAS机制,可以保证多线程下对元素的原子操作。AtomicIntegerArray、AtomicLongArray和AtomicReferenceArray三者不同之处就在于数组中保存的元素类型不同,分别为整型、长整形和对象引用。
AtomicIntegerArray
讲解AtomicIntegerArray的实现原理前我们先看一个简单的例子,有一个长度为2的整型数组&#x