使用 AtomicInteger 进行计数(java多线程优化)

通常,在我们实现多线程使用的计数器或随机数生成器时,会使用锁来保护共享变量。这样做的弊端是如果锁竞争的太厉害,会损害吞吐量,因为竞争的同步非常昂贵。

volatile 变量虽然可以使用比同步更低的成本存储共享变量,但它只可以保证其他线程能够立即看到对 volatile 变量的写入,无法保证读 - 修改 - 写的原子性。因此,volatile 变量无法用来实现正确的计数器和随机数生成器。

从 JDK 5 开始,java.util.concurrent.atomic 包中引入了原子变量,包括 AtomicInteger、AtomicLong、AtomicBoolean 以及数组 AtomicIntergerArray、AtomicLongArray 。原子变量保证了 ++--+=-= 等操作的原子性。利用这些数据结构,您可以实现更高效的计数器和随机数生成器。

posted @ 2013-08-31 23:20  成风魄郎  阅读(1947)  评论(0编辑  收藏  举报