java.util.concurrent和java.util.concurrent.atomic和java.util.concurrent.locks包括非常有用的并發(fā)構(gòu)造。
線程并發(fā)包以四種方式支持并發(fā)。
原子變量類的命名類似于AtomicXxx,例如,AtomicInteger類用于表示一個(gè)int變量。
原子變量可用于在不使用任何鎖的情況下以原子方式對單個(gè)變量執(zhí)行多個(gè)指令。
AtomicInteger,AtomicLong和AtomicBoolean類分別支持對原始數(shù)據(jù)類型int,long和boolean的操作。
當(dāng)引用變量需要以原子方式更新時(shí),AtomicReference類用于處理引用數(shù)據(jù)類型。
有三個(gè)類稱為AtomicIntegerArray,AtomicLongArray和AtomicReferenceArray,它們表示一個(gè)int,long和引用類型的數(shù)組,其元素可以進(jìn)行原子性更新。
有三個(gè)類稱為AtomicLongFieldUpdater,AtomicIntegerFieldUpdater和AtomicReferenceFieldUpdater,可用于使用反射以原子方式更新類的易失性字段。
要獲得對這些類的對象的引用,您需要使用他們的工廠方法newUpdater()。
以下代碼顯示如何使用AtomicLong類來創(chuàng)建計(jì)數(shù)器。
import java.util.concurrent.atomic.AtomicLong; public class AtomicCounter { private AtomicLong value = new AtomicLong(0L); public long next() { return value.incrementAndGet(); } }
更多建議: