W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
java.util.concurrent和java.util.concurrent.atomic和java.util.concurrent.locks包括非常有用的并發(fā)構(gòu)造。
線程并發(fā)包以四種方式支持并發(fā)。
原子變量類的命名類似于AtomicXxx,例如,AtomicInteger類用于表示一個(gè)int變量。
原子變量可用于在不使用任何鎖的情況下以原子方式對(duì)單個(gè)變量執(zhí)行多個(gè)指令。
AtomicInteger,AtomicLong和AtomicBoolean類分別支持對(duì)原始數(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,可用于使用反射以原子方式更新類的易失性字段。
要獲得對(duì)這些類的對(duì)象的引用,您需要使用他們的工廠方法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(); } }
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: