您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)java怎樣避免死鎖,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
死鎖
索是一個(gè)非常有用的工具,運(yùn)用場(chǎng)景非常多,因?yàn)樗褂闷饋?lái)非常簡(jiǎn)單,而且易于理解。但同時(shí)它也會(huì)帶來(lái)一些困擾,那就是可能會(huì)引起死鎖,一旦產(chǎn)生死鎖,就會(huì)造成系統(tǒng)功能不可用。讓我們先來(lái)看一段代碼,這段代碼會(huì)引起死鎖,使線程 thread_1 和線程 thread_2 互相等待對(duì)方釋放鎖。
package thread; public class DeadLockDemo { private static String A = "A"; private static String B = "B"; public static void main(String args[]) { new DeadLockDemo().deadLock(); } private void deadLock() { // 線程thread_1 Thread thread_1 = new Thread(new Runnable() { @Override public void run() { synchronized (A) { System.err.println("--thread_1 lock A----"); synchronized (B) { System.err.println("--thread_1 lock B----"); } } } } ); // 線程thread_2 Thread thread_2 = new Thread(new Runnable() { @Override public void run() { synchronized (B) { System.out.println("--thread_2 lock B----"); synchronized (A) { System.out.println("--thread_2 lock A----"); } } } } ); thread_1.start(); thread_2.start(); } }
這段代碼只是演示死鎖的場(chǎng)景,在現(xiàn)實(shí)中你可能不會(huì)寫(xiě)出這樣的代碼。但是在一些更為復(fù)雜的場(chǎng)景中,你可能會(huì)遇到這樣的問(wèn)題,比如 thread_1 拿到索之后,因?yàn)橐恍┊惓G闆r沒(méi)有釋放索(死循環(huán))。又或者是 thread_1 拿到一個(gè)數(shù)據(jù)庫(kù)索,釋放鎖的時(shí)候拋出了異常,沒(méi)釋放掉。
一旦出現(xiàn)死鎖,業(yè)務(wù)是可感知的,因?yàn)椴荒芾^續(xù)提供服務(wù)了,那么只能通過(guò)dump 線程查看到底是哪個(gè)線程出現(xiàn)了問(wèn)題,以下線程信息告訴我們是 DeadLockDemo類(lèi)的第 35 行和21行引起了死鎖。
"Thread-1" prio=6 tid=0x000000000cb13800 nid=0x19ac waiting for monitor entry [0 x000000000d67f000] java.lang.Thread.State: BLOCKED (on object monitor) at thread.DeadLockDemo$2.run(DeadLockDemo.java:35) - waiting to lock <0x00000007d5a9be88> (a java.lang.String) - locked <0x00000007d5a9beb8> (a java.lang.String) at java.lang.Thread.run(Unknown Source) "Thread-0" prio=6 tid=0x000000000cb0e800 nid=0x6bc waiting for monitor entry [0x 000000000d48f000] java.lang.Thread.State: BLOCKED (on object monitor) at thread.DeadLockDemo$1.run(DeadLockDemo.java:21) - waiting to lock <0x00000007d5a9beb8> (a java.lang.String) - locked <0x00000007d5a9be88> (a java.lang.String) at java.lang.Thread.run(Unknown Source)
避免死鎖的幾個(gè)常見(jiàn)方法。
避免一個(gè)線程同時(shí)獲取多個(gè)鎖。
避免一個(gè)線程在索內(nèi)同時(shí)占用多個(gè)資源,盡量保證每個(gè)索只占用一個(gè)資源。
嘗試使用定時(shí)索,使用 lock.tryLock(timeout) 來(lái)替代使用內(nèi)部索機(jī)制。
對(duì)于數(shù)據(jù)庫(kù)索,加鎖和解鎖必須在一個(gè)數(shù)據(jù)庫(kù)連接里,否則會(huì)出現(xiàn)解鎖失敗的情況。
關(guān)于“java怎樣避免死鎖”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。