17 Go并發(fā)編程(四):Go并發(fā)編程的陷阱

協(xié)程死鎖

學完Go的協(xié)程與通道问麸,我們已經(jīng)對Go的并發(fā)編程有大概的了解伙判,可以說go的并發(fā)程序還是很容易編寫的,只要深刻理解go的協(xié)程和通道設計衔憨,日常使用不會出現(xiàn)很大問題叶圃。但凡事都有些許例外情況,就像你去登山越野践图,即使你手中有路線圖掺冠,但現(xiàn)實環(huán)境還是有出入的,你還是有可能踩到陷阱码党。Go的并發(fā)編程有些情況會造成死鎖導致程序退出德崭。

所謂死鎖,Go運行時報錯有個有趣的說法:

fatal error:all goroutines are asleep-deadlock —— 所有的協(xié)程都在睡覺揖盘,可以理解為所有的協(xié)程都在等待資源

下面演示幾種造成死鎖的情況:

1.自我阻塞

一個沒有緩存的管道必須有另一個協(xié)程的讀取才能寫入眉厨,否則當前協(xié)程永遠都在等待寫入管道。

/*自己阻塞自己*/
func BaseDeadlock01() {
    //申請一個沒有緩存的管道
    ch := make(chan int, 0)
    ch <- 123
    x := <-ch //零緩存的管道兽狭,有寫必須由另一個協(xié)程讀憾股,否則死鎖
    fmt.Println(x)
}

2.協(xié)程開遲了

一個屋緩存的管道鹿蜀,必須先開啟另一個協(xié)程才能寫入,否則協(xié)程等同于沒開——死鎖服球。

/*協(xié)程開晚了*/
func Baseeadlock02() {
    ch := make(chan int)
    
    //數(shù)據(jù)應在協(xié)程開開啟后才寫入
    ch <- 123
    
    go func() {
        x := <-ch
        fmt.Println(x)
    }()
}

3.互搶資源

管道讀寫時,相互要求對方先讀/寫,自己在寫/讀,造成死鎖

//演示一個錢貨交易的例子
func BaseDeadlock03() {
    //無緩存的錢包通道
    chMoney := make(chan int)
    //無緩存的貨物通道
    chGoods := make(chan int)
    
    //商戶子協(xié)程:先給錢再發(fā)貨茴恰!
    go func() {
        for {
            select {
            case <-chMoney:
                fmt.Println("先給錢再給貨!U缎堋往枣!")
                chGoods <- 100
            }
        }

    }()
    
    //客戶主協(xié)程:先發(fā)貨再給錢
    for {
        select {
        case <-chGoods:
            fmt.Println("先發(fā)貨再給錢!W怼婉商!")
            chMoney <- 100
        }
    }

}

4.隱性死鎖

有些情況是子協(xié)程直接互相等待各自需要的資源,主協(xié)程沒有發(fā)現(xiàn)而導致隱性死鎖渣叛,這類死鎖運行時不會報錯退出丈秩,但會直接卡死其中的兩個子協(xié)程,占用系統(tǒng)資源

/*讀寫鎖定相互阻塞,形成隱形死鎖*/
func BaseDeadlock04() {

    //無緩存的錢包通道
    chMoney := make(chan int)
    //無緩存的貨物通道
    chGoods := make(chan int)
    
    //商戶子協(xié)程:先給錢再發(fā)貨淳衙!
    go func() {
        for {
            select {
            case <-chMoney:
                fmt.Println("先給錢再給貨D⒒唷!箫攀!")
                chGoods <- 100
            }
        }

    }()
    ?
    //客戶主協(xié)程:先發(fā)貨再給錢
    go func() {
        for {
            select {
            case <-chGoods:
                fmt.Println("先發(fā)貨再給錢3ι!靴跛!")
                chMoney <- 100
            }
        }
    }()
    
    //主協(xié)程并不知道其調(diào)用的兩個子協(xié)程在互搶各自都不釋放的資源
    for {
        time.Sleep(time.Second)
        runtime.GC() //通知垃圾回收器清理吧
    }

}

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末缀雳,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子梢睛,更是在濱河造成了極大的恐慌肥印,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,029評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件绝葡,死亡現(xiàn)場離奇詭異深碱,居然都是意外死亡,警方通過查閱死者的電腦和手機藏畅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,395評論 3 385
  • 文/潘曉璐 我一進店門敷硅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人愉阎,你說我怎么就攤上這事绞蹦。” “怎么了榜旦?”我有些...
    開封第一講書人閱讀 157,570評論 0 348
  • 文/不壞的土叔 我叫張陵坦辟,是天一觀的道長。 經(jīng)常有香客問我章办,道長锉走,這世上最難降的妖魔是什么滨彻? 我笑而不...
    開封第一講書人閱讀 56,535評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮挪蹭,結果婚禮上亭饵,老公的妹妹穿的比我還像新娘。我一直安慰自己梁厉,他們只是感情好辜羊,可當我...
    茶點故事閱讀 65,650評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著词顾,像睡著了一般八秃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上肉盹,一...
    開封第一講書人閱讀 49,850評論 1 290
  • 那天昔驱,我揣著相機與錄音,去河邊找鬼上忍。 笑死骤肛,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的窍蓝。 我是一名探鬼主播腋颠,決...
    沈念sama閱讀 39,006評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼吓笙!你這毒婦竟也來了淑玫?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 37,747評論 0 268
  • 序言:老撾萬榮一對情侶失蹤面睛,失蹤者是張志新(化名)和其女友劉穎絮蒿,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體侮穿,經(jīng)...
    沈念sama閱讀 44,207評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡歌径,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,536評論 2 327
  • 正文 我和宋清朗相戀三年毁嗦,在試婚紗的時候發(fā)現(xiàn)自己被綠了亲茅。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,683評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡狗准,死狀恐怖克锣,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情腔长,我是刑警寧澤袭祟,帶...
    沈念sama閱讀 34,342評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站捞附,受9級特大地震影響巾乳,放射性物質(zhì)發(fā)生泄漏您没。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,964評論 3 315
  • 文/蒙蒙 一胆绊、第九天 我趴在偏房一處隱蔽的房頂上張望氨鹏。 院中可真熱鬧,春花似錦压状、人聲如沸仆抵。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,772評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽镣丑。三九已至,卻和暖如春娱两,著一層夾襖步出監(jiān)牢的瞬間莺匠,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,004評論 1 266
  • 我被黑心中介騙來泰國打工谷婆, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留慨蛙,地道東北人。 一個月前我還...
    沈念sama閱讀 46,401評論 2 360
  • 正文 我出身青樓纪挎,卻偏偏與公主長得像期贫,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子异袄,可洞房花燭夜當晚...
    茶點故事閱讀 43,566評論 2 349

推薦閱讀更多精彩內(nèi)容