java.util.concurrent.atomic包定义了支持单个变量的原子操做的类,全部类都有get
和set
方法,相似于对volatile
变量的读写操做,也就是说,set
与在同一个变量上任何后续的get
具备先发生关系,compareAndSet
原子方法也具备这些内存一致性特性,适用于整数原子变量的简单原子算法也是如此。html
要查看如何使用此包,让咱们返回咱们最初用于演示线程干扰的Counter类:java
class Counter { private int c = 0; public void increment() { c++; } public void decrement() { c--; } public int value() { return c; } }
使Counter
免受线程干扰的一种方法是使其方法同步,如在SynchronizedCounter中:c++
class SynchronizedCounter { private int c = 0; public synchronized void increment() { c++; } public synchronized void decrement() { c--; } public synchronized int value() { return c; } }
对于这个简单的类,同步是可接受的解决方案,可是对于更复杂的类,咱们可能但愿避免没必要要的同步对活性的影响,用AtomicInteger
替换int
字段容许咱们在不使用同步的状况下防止线程干扰,如在AtomicCounter中:git
import java.util.concurrent.atomic.AtomicInteger; class AtomicCounter { private AtomicInteger c = new AtomicInteger(0); public void increment() { c.incrementAndGet(); } public void decrement() { c.decrementAndGet(); } public int value() { return c.get(); } }