在Java項(xiàng)目中實(shí)現(xiàn)多線程并發(fā)編程的方法?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來(lái)自于我們對(duì)這個(gè)行業(yè)的熱愛(ài)。我們立志把好的技術(shù)通過(guò)有效、簡(jiǎn)單的方式提供給客戶,將通過(guò)不懈努力成為客戶在信息化領(lǐng)域值得信任、有價(jià)值的長(zhǎng)期合作伙伴,公司提供的服務(wù)項(xiàng)目有:主機(jī)域名、網(wǎng)絡(luò)空間、營(yíng)銷軟件、網(wǎng)站建設(shè)、平邑網(wǎng)站維護(hù)、網(wǎng)站推廣。Java 中的鎖通常分為兩種:
通過(guò)關(guān)鍵字 synchronized 獲取的鎖,我們稱為同步鎖,上一篇有介紹到:Java 多線程并發(fā)編程 Synchronized 關(guān)鍵字。
java.util.concurrent(JUC)包里的鎖,如通過(guò)繼承接口 Lock 而實(shí)現(xiàn)的 ReentrantLock(互斥鎖),繼承 ReadWriteLock 實(shí)現(xiàn)的 ReentrantReadWriteLock(讀寫鎖)。
本篇主要介紹 ReentrantLock(互斥鎖)。
ReentrantLock(互斥鎖)
ReentrantLock 互斥鎖,在同一時(shí)間只能被一個(gè)線程所占有,在被持有后并未釋放之前,其他線程若想獲得該鎖只能等待或放棄。
ReentrantLock 互斥鎖是可重入鎖,即某一線程可多次獲得該鎖。
公平鎖 and 非公平鎖
public ReentrantLock() { sync = new NonfairSync(); } public ReentrantLock(boolean fair) { sync = fair ? new FairSync() : new NonfairSync(); }