首頁 >後端開發 >Golang >golang 如何處理死鎖

golang 如何處理死鎖

(*-*)浩
(*-*)浩原創
2019-12-30 15:37:372867瀏覽

golang 如何處理死鎖

死鎖

死鎖是指兩個或兩個以上的協程的執行過程中,由於競爭資源或由於彼此通信而造成的一種阻塞的現象,若無外力作用,他們將無法推進下去。 (推薦學習:go

常見的死鎖

場景1:一個通道在一個go程讀取寫入

func main() {
	c:=make(chan int)
	c<-88
	<-c
}

場景二:go程開啟前使用通道

func main() {
	c:=make(chan int)
	c<-88
	go func() {
		<-c
	}()
}

場景三:通道1中呼叫了通道2,在通道2中呼叫通道1

func main() {
	c1,c2:=make(chan int),make(chan int)
	go func() {
		for  {
			select{
				case <-c1:
					c2<-10
			}
		}
	}()
	for  {
		select{
		case <-c2:
			c1<-10
		}
	}	
}

死鎖的出現的情況很多,但都不外乎是爭搶資源和資料通訊所引起。

解決死鎖的方法是加鎖。

以上是golang 如何處理死鎖的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn