亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何安全地關閉延遲塊中的通道?

如何安全地關閉延遲塊中的通道?

Go
慕的地6264312 2023-03-15 15:24:33
考慮以下示例:package mainimport (    "fmt"    "time")func main() {    ticker := time.NewTicker(2 * time.Second)    done := make(chan bool)    defer func() {        fmt.Println("exiting..")        done <- true        close(done)    }()    go func(ticker *time.Ticker, done chan bool) {        for {            select {            case <-done:                fmt.Println("DONE!")                break            case <-ticker.C:                fmt.Println("TICK!...")            }        }    }(ticker, done)    time.Sleep(7 * time.Second)}等待接收的 goroutine 從未done接收到(我猜)主 goroutine 預先完成。但是,如果我將主 goroutine 的睡眠時間更改為 8 秒,它會收到一條消息;為什么對睡眠時間有這種依賴性?是不是因為有第二個區別讓 goroutine 保持活力并且沒有足夠的時間殺死它?我該如何優雅地殺死 goroutine?
查看完整描述

1 回答

?
MMMHUHU

TA貢獻1834條經驗 獲得超8個贊

您需要確保 main 在 goroutine 完成之前不會返回。

最簡單的方法是使用 WaitGroup:


var wg sync.WaitGroup

defer wg.Wait()

wg.Add(1)

go func() {

    defer wg.Done()

    // …

注意defers是逆序運行的,所以一定要放在defer wg.Wait()之前defer close(done),否則會死鎖。


查看完整回答
反對 回復 2023-03-15
  • 1 回答
  • 0 關注
  • 114 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號