什么是原子操作

2024-05-21 16:24:52 浏览数 (2)

什么是原子操作?

原子操作(atomic operation)意为”不可被中断的一个或一系列操作” 。

处理器使用基于对缓存加锁或总线加锁的方式来实现多处理器之间的原子操作。在Java 中可以通过锁和循环CAS的方式来实现原子操作。CAS操作——Compare & Set,或是Compare & Swap,现在几乎所有的CPU 指令都支持CAS的原子操作。

原子操作就是: 不可中断的一个或者一系列操作, 也就是不会被线程调度机制打断的操作, 运行期间不会有任何的上下文切换(context switch)。原子操作是在多线程环境下避免数据不一致必须的手段。

int 并不是一个原子操作,所以当一个线程读取它的值并加 1 时,另外一个线程有可能会读到之前的值,这就会引发错误。

为了解决这个问题,必须保证增加操作是原子的,在 JDK1.5 之前我们可以使用同步技术来做到这一点。

到JDK1.5,java.util.concurrent.atomic 包提供了 int 和 long 类型的原子包装类,它们可以自动的保证对于他们的操作是原子的并且不需要使用同步。

在Java Concurrency API 中有哪些原子类(atomic classes)

java.util.concurrent 这个包里面提供了一组原子类。

其基本的特性就是在多线程环境下, 当有多个线程同时执行这些类的实例包含的方法时,具有排他性,即当某个线程进入方法,执行其中的指令时,不会被其他线程打断,而别的线程就像自旋锁一样,一直等到该方法执行完成,才由 JVM 从等待队列中选择另一个线程进入,这只是一种逻辑上的理解。

  1. 原子类: AtomicBoolean,AtomicInteger, AtomicLong, AtomicReference
  2. 原子数组:AtomicIntegerArray, AtomicLongArray,AtomicReferenceArray
  3. 原子属性更新器: AtomicLongFieldUpdater, AtomicIntegerFieldUpdater,AtomicReferenceFieldUpdater
  4. 解决ABA 问题的原子类:AtomicMarkableReference(通过引入一个boolean来反映中间有没有变过),AtomicStampedReference(通过引入一个int 来累加来反映中间有没有变过)。

0 人点赞