小編給大家分享一下如何解決Java多線程的臨界資源問題,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
創(chuàng)新互聯(lián)10年專注成都高端網(wǎng)站建設(shè)按需網(wǎng)站策劃服務(wù),為客戶提供專業(yè)的成都網(wǎng)站制作,成都網(wǎng)頁設(shè)計,成都網(wǎng)站設(shè)計服務(wù);創(chuàng)新互聯(lián)服務(wù)內(nèi)容包含成都網(wǎng)站建設(shè),微信小程序開發(fā),軟件開發(fā),網(wǎng)絡(luò)營銷推廣,網(wǎng)絡(luò)運(yùn)營服務(wù)及企業(yè)形象設(shè)計;創(chuàng)新互聯(lián)擁有眾多專業(yè)的高端網(wǎng)站制作開發(fā)團(tuán)隊(duì),資深的高端網(wǎng)頁設(shè)計團(tuán)隊(duì)及經(jīng)驗(yàn)豐富的架構(gòu)師高端網(wǎng)站策劃團(tuán)隊(duì);我們始終堅持從客戶的角度出發(fā),為客戶量身訂造網(wǎng)絡(luò)營銷方案,解決網(wǎng)絡(luò)營銷疑問。臨界資源問題的原因:某一個線程在對臨界資源進(jìn)行訪問時,還沒來得及完全修改臨界資源的值,臨界資源就被其他線程拿去訪問,導(dǎo)致多個線程訪問同一資源。直觀表現(xiàn)為打印結(jié)果順序混亂。
解決方法:加鎖
靜態(tài)方法中用類鎖,非靜態(tài)方法中用對象鎖。
1.同步代碼段:synchronized(){...}
2.同步方法:使用關(guān)鍵字synchronized修飾的方法
3.使用顯式同步鎖ReentrantLock
鎖池描述的即為鎖外等待的狀態(tài)
方法一:同步代碼段:synchronized(){...}
public class SourceConflict { public static void main(String[] args) { //實(shí)例化4個售票員,用4個線程模擬4個售票員 Runnable r = () -> { while (TicketCenter.restCount > 0) { synchronized(" ") { if (TicketCenter.restCount <= 0) { return; } System.out.println(Thread.currentThread().getName() + "賣出一張票,剩余" + --TicketCenter.restCount + "張票"); } } }; //用4個線程模擬4個售票員 Thread thread1 = new Thread(r, "thread-1"); Thread thread2 = new Thread(r, "thread-2"); Thread thread3 = new Thread(r, "thread-3"); Thread thread4 = new Thread(r, "thread-4"); //開啟線程 thread1.start(); thread2.start(); thread3.start(); thread4.start(); } } //實(shí)現(xiàn)四名售票員共同售票,資源共享,非獨(dú)立 //Lambda表達(dá)式或匿名內(nèi)部類內(nèi)部捕獲的局部變量必須顯式的聲明為 final 或?qū)嶋H效果的的 final 類型,而捕獲實(shí)例或靜態(tài)變量是沒有限制的 class TicketCenter{ public static int restCount = 100; }
方法二:同步方法,即使用關(guān)鍵字synchronized修飾的方法
public class SourceConflict2 { public static void main(String[] args) { //實(shí)例化4個售票員,用4個線程模擬4個售票員 Runnable r = () -> { while (TicketCenter.restCount > 0) { sellTicket(); } }; //用4個線程模擬4個售票員 Thread thread1 = new Thread(r, "thread-1"); Thread thread2 = new Thread(r, "thread-2"); Thread thread3 = new Thread(r, "thread-3"); Thread thread4 = new Thread(r, "thread-4"); //開啟線程 thread1.start(); thread2.start(); thread3.start(); thread4.start(); } private synchronized static void sellTicket() { if (TicketCenter.restCount <= 0) { return; } System.out.println(Thread.currentThread().getName() + "賣出一張票,剩余" + --TicketCenter.restCount + "張票"); } } class TicketCenter{ public static int restCount = 100; }
方法三:使用顯式同步鎖ReentrantLock
import java.util.concurrent.locks.ReentrantLock; public class SourceConflict3 { public static void main(String[] args) { //實(shí)例化4個售票員,用4個線程模擬4個售票員 //顯式鎖 ReentrantLock lock = new ReentrantLock(); Runnable r = () -> { while (TicketCenter.restCount > 0) { lock.lock(); if (TicketCenter.restCount <= 0) { return; } System.out.println(Thread.currentThread().getName() + "賣出一張票,剩余" + --TicketCenter.restCount + "張票"); lock.unlock(); } }; //用4個線程模擬4個售票員 Thread thread1 = new Thread(r, "thread-1"); Thread thread2 = new Thread(r, "thread-2"); Thread thread3 = new Thread(r, "thread-3"); Thread thread4 = new Thread(r, "thread-4"); //開啟線程 thread1.start(); thread2.start(); thread3.start(); thread4.start(); } } class TicketCenter{ public static int restCount = 100; }
看完了這篇文章,相信你對“如何解決Java多線程的臨界資源問題”有了一定的了解,如果想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道,感謝各位的閱讀!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。