當前位置:
首頁 >
golang中的死锁
發(fā)布時間:2025/6/15
30
豆豆
生活随笔
收集整理的這篇文章主要介紹了
golang中的死锁
小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
簡介
出現(xiàn)死鎖的情況
- 單go協(xié)程自己死鎖
- go協(xié)程之間channel訪問順序?qū)е滤梨i
- 多go協(xié)程,多channel交叉死鎖
盡量不要將讀寫鎖和互斥鎖和channel混用,有可能造成隱式死鎖,還不報錯
單go協(xié)程自己死鎖
channel至少在2個協(xié)程中進行
func main() {s:= make(chan int)//寫入channel,寫端阻塞,阻塞當前,下面就全部阻塞了,就沒機會執(zhí)行了s<-11//他能解鎖,但是已經(jīng)被阻塞了m := <-sfmt.Println(m) }輸出
fatal error: all goroutines are asleep - deadlock!go協(xié)程之間channel訪問順序?qū)е滤梨i
使用一端寫的時候,保證另一端有機會讀取,代碼寫下面
func main() {ch:= make(chan int)//讀取,阻塞,阻塞了下面就不執(zhí)行了,除非把他放在go func的下面m := <-chfmt.Println(m)go func() {//他能解鎖,但是主程序在之前就阻塞了ch <- 11}() }多go協(xié)程,多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}} }總結(jié)
以上是生活随笔為你收集整理的golang中的死锁的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: golang中的select详解
- 下一篇: golang中的互斥锁