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

golang 如何處理死鎖

(*-*)浩
發布: 2019-12-30 15:37:37
原創
2836 人瀏覽過

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中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板