溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

java怎樣避免死鎖

發(fā)布時(shí)間:2021-08-13 10:52:00 來(lái)源:億速云 閱讀:160 作者:小新 欄目:編程語(yǔ)言

這篇文章將為大家詳細(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)把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(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)容。

AI