JAVA多執行緒死鎖詳解

2021-08-05 23:38:40 字數 1167 閱讀 7216

需要避免的與多工處理有關的特殊錯誤型別是死鎖(deadlock)。

死鎖發生在當兩個執行緒對一對同步物件有迴圈依賴關係時。例如,假定乙個執行緒進入了物件x的管程而另乙個執行緒進入了物件y的管程。如果x的執行緒試圖呼叫y的同步方法,它將像預料的一樣被鎖定。而y的執行緒同樣希望呼叫x的一些同步方法,執行緒永遠等待,因為為到達x,必須釋放自己的y的鎖定以使第乙個執行緒可以完成。死鎖是很難除錯的錯誤,因為:

為充分理解死鎖,觀察它的行為是很有用的。下面的例子生成了兩個類,a和b,分別有foo( )和bar( )方法。這兩種方法在呼叫其他類的方法前有乙個短暫的停頓。主類,名為deadlock,建立了a和b的例項,然後啟動第二個執行緒去設定死鎖環境。foo( )和bar( )方法使用sleep( )強迫死鎖現象發生。

// an example of deadlock.

class a catch(exception e)

system.out.println(name + " trying to call b.last()");

b.last();

}synchronized void last() }

class b catch(exception e)

system.out.println(name + " trying to call a.last()");

a.last();

}synchronized void last() }

class deadlock implements runnable

public void run()

public static void main(string args)

}執行程式後,輸出如下:

mainthread entered a.foo

racingthread entered b.bar

mainthread trying to call b.last()

racingthread trying to call a.last()

因為程式死鎖,你需要按ctrl-c來結束程式。在pc機上按ctrl-break(或在solaris下按ctrl-\)你可以看到全線程和管程緩衝堆。你會看到racingthread在等待管程a時占用管程b,同時,mainthread占用a等待b。該程式永遠都不會結束。像該例闡明的,你的多執行緒程式經常被鎖定,死鎖是你首先應檢查的問題。

Java多執行緒 死鎖

死鎖 不同的執行緒分別占用對方需要的同步資源不放棄,都在等待對方放棄自己的需要的同步資源,就形成了執行緒的死鎖 解決方法 1.專門的演算法 原則 2.儘量減少同步資源的定義 此處插入testdeadlock 死鎖問題,處理執行緒同步時容易出現 public class testdeadlock ca...

Java 多執行緒死鎖

概念 所謂死鎖是指兩個或兩個以上的程序在執行過程中,因爭奪同一資源而造成的一種互相等待的現象,若無外力作用,它們都將無法進行下去,此時稱系統處於死鎖狀態或系統產生了死鎖,class k extends thread public void run else catch interruptedexce...

Java多執行緒 執行緒死鎖

發生死鎖的原因通常是兩個物件的鎖相互等待造成的。以下用乙個例項來構造這樣的情況 package basic.e deadlock import org.apache.log4j.logger public class testdeadlock class mythread extends threa...