W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
java.util.concurrent和java.util.concurrent.atomic和java.util.concurrent.locks包括非常有用的并發(fā)構(gòu)造。
線程并發(fā)包以四種方式支持并發(fā)。
原子變量類的命名類似于AtomicXxx,例如,AtomicInteger類用于表示一個int變量。
原子變量可用于在不使用任何鎖的情況下以原子方式對單個變量執(zhí)行多個指令。
AtomicInteger,AtomicLong和AtomicBoolean類分別支持對原始數(shù)據(jù)類型int,long和boolean的操作。
當(dāng)引用變量需要以原子方式更新時,AtomicReference類用于處理引用數(shù)據(jù)類型。
有三個類稱為AtomicIntegerArray,AtomicLongArray和AtomicReferenceArray,它們表示一個int,long和引用類型的數(shù)組,其元素可以進(jìn)行原子性更新。
有三個類稱為AtomicLongFieldUpdater,AtomicIntegerFieldUpdater和AtomicReferenceFieldUpdater,可用于使用反射以原子方式更新類的易失性字段。
要獲得對這些類的對象的引用,您需要使用他們的工廠方法newUpdater()。
以下代碼顯示如何使用AtomicLong類來創(chuàng)建計數(shù)器。
import java.util.concurrent.atomic.AtomicLong; public class AtomicCounter { private AtomicLong value = new AtomicLong(0L); public long next() { return value.incrementAndGet(); } }
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: