作者简介:笔名seaboat,擅长工程算法、人工智能算法、自然语言处理、计算机视觉、架构、分布式、高并发、大数据和搜索引擎等方面的技术,大多数编程语言都会使用,但更擅长Java、Python和C++。平时喜欢看书写作、运动、画画。崇尚技术自由,崇尚思想自由。出版书籍:《Tomcat内核设计剖析》、《图解数据结构与算法》、《图解Java并发原理》、《人工智能原理科普》。
什么是AtomicInteger
AtomicInteger是JDK为我们提供的原子整型,可以拆分为Atomic和Integer两个关键词,即能保证原子性的整型操作。通过它能在多线程的场景下安全并发的操作某个整型变量,保证对整型变量操作的正确性。
实现思想
要理解AtomicInteger的实现思想就必须先理解CAS算法,CAS(Compare and Swap),即比较并交换。它涉及到三个操作数:内存值、预期值、新值。当且仅当预期值和内存值相等时才能将内存值修改为新值,处理的逻辑是:先检查某个内存值是否跟该线程之前读取时的值一样,如不一样则表示期间此内存值已经被别的线程更改过了,应该舍弃本次操作。否则说明期间没有其它线程对此内存值更改,所以可以用新值来更新内存值。
如下图,两个线程并发地对某内存值进行操作&#