我有三個(gè)并發(fā)的go例程,如下所示,func Routine1() { mutex1.Lock() do something mutex2.Lock() mutex3.Lock() send int to routine 2 send int to routine 3 * Print Something * mutex2.Unlock() mutex3.Unlock() receive ints do something mutex2.Lock() mutex3.Lock() send int to routine 2 send int to routine 3 Print Something mutex2.Unlock() mutex3.Unlock() do something receive ints mutex1.Unlock() wg.Done()}func Routine2() { mutex2.Lock() do something mutex1.Lock() mutex3.Lock() send int to routine 1 send int to routine 3 Print Something mutex1.Unlock() mutex3.Unlock() do something receive ints mutex1.Lock() mutex3.Lock() send int to routine 1 send int to routine 3 Print Something mutex1.Unlock() mutex3.Unlock() do something receive ints mutex2.Unlock() wg.Done()}func Routine3() {// same structure as routine 1 & 2}func main() {wg.Add(3)go Routine1()go Routine2()Routine3()wg.Wait()}該邏輯代碼每次都會(huì)出現(xiàn)死鎖情況。實(shí)際上,當(dāng)它運(yùn)行時(shí),只需多次執(zhí)行例程1的打印語句(*標(biāo)記之間的語句)(盡管我的打印語句只是一個(gè)),并給出死鎖錯(cuò)誤。有人可以告訴我代碼邏輯有什么問題嗎?謝謝。注意 有關(guān)更多信息,請(qǐng)參見http://play.golang.org/p/pW6aXryUaK,此處僅執(zhí)行第290行。包含錯(cuò)誤的原始代碼可以在play.golang.org/p/UL3rj8DJRk中找到。我只是向他們添加鎖定和解鎖。謝謝。我想補(bǔ)充一點(diǎn):在play.golang.org/p/UL3rj8DJRk代碼中,您可以找到各種打印語句的輸出,如下所示:進(jìn)程[number]在[時(shí)間納秒]上將[int]發(fā)送到[number]到進(jìn)程[number] ]。但是,由于這三個(gè)并發(fā)例程的結(jié)果,有時(shí)print語句無法正確執(zhí)行(意味著未完全打印,這是另一張打印插入的東西,例如進(jìn)程[number]將[int]發(fā)送到進(jìn)程[number]的進(jìn)程[number] ])。有人可以幫我解決這個(gè)問題嗎?
1 回答

慕哥6287543
TA貢獻(xiàn)1831條經(jīng)驗(yàn) 獲得超10個(gè)贊
由于您發(fā)布的代碼沒有足夠的信息,因此無法確定死鎖的原因。
這可能是由于您獲取鎖的順序引起的,也可能是由于使用了未緩沖的Go通道引起的。
在發(fā)布完整的Go源代碼之前,您無法回答問題。
如果您需要討論更長的代碼,則可能應(yīng)該將其發(fā)布到golang-nuts上。
- 1 回答
- 0 關(guān)注
- 237 瀏覽
添加回答
舉報(bào)
0/150
提交
取消