golang中的死锁
生活随笔
收集整理的這篇文章主要介紹了
golang中的死锁
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
簡介
出現死鎖的情況
- 單go協程自己死鎖
- go協程之間channel訪問順序導致死鎖
- 多go協程,多channel交叉死鎖
盡量不要將讀寫鎖和互斥鎖和channel混用,有可能造成隱式死鎖,還不報錯
單go協程自己死鎖
channel至少在2個協程中進行
func main() {s:= make(chan int)//寫入channel,寫端阻塞,阻塞當前,下面就全部阻塞了,就沒機會執行了s<-11//他能解鎖,但是已經被阻塞了m := <-sfmt.Println(m) }輸出
fatal error: all goroutines are asleep - deadlock!go協程之間channel訪問順序導致死鎖
使用一端寫的時候,保證另一端有機會讀取,代碼寫下面
func main() {ch:= make(chan int)//讀取,阻塞,阻塞了下面就不執行了,除非把他放在go func的下面m := <-chfmt.Println(m)go func() {//他能解鎖,但是主程序在之前就阻塞了ch <- 11}() }多go協程,多channel交叉死鎖
func main() {ch1 := make(chan int)ch2 := make(chan int)go func() { //子for {select {//讀操作阻塞case num := <-ch1://寫ch2 <- num}}}()for { //主select {//讀case num := <-ch2://寫ch1 <- num}} }總結
以上是生活随笔為你收集整理的golang中的死锁的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: golang中的select详解
- 下一篇: golang中的互斥锁