首頁 > 後端開發 > Golang > 為什麼我的自訂「超時等待頻道」不起作用以及如何使其起作用?

為什麼我的自訂「超時等待頻道」不起作用以及如何使其起作用?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
發布: 2024-02-12 23:06:09
轉載
1112 人瀏覽過

為什麼我的自訂「超時等待頻道」不起作用以及如何使其起作用?

php小編小新在使用自訂「超時等待頻道」時,可能會遇到它不起作用的情況。這可能是由於一些常見的問題導致的,例如錯誤的配置或程式碼問題。為了使自訂「超時等待頻道」起作用,我們可以採取一些解決方法。首先,我們需要確保正確地配置了頻道和逾時時間。其次,我們可以檢查程式碼中是否有任何錯誤或邏輯問題,可能導致逾時等待頻道不起作用。最後,我們也可以考慮使用其他相關的技術或工具來處理逾時等待問題,例如使用封裝庫或使用定時器來監控和處理逾時情況。透過這些方法,我們可以使自訂「超時等待頻道」正常運作,提高我們的應用程式的效能和穩定性。

問題內容

我正在嘗試製作自己的自訂「頻道超時」。更準確地說,是其中的 time.after 函數。換句話說,我正在嘗試實現這個:

select {
case v := <-c:
    fmt.println("value v: ", v)
case <-time.after(1 * time.second):
    fmt.println("timeout")
}
登入後複製

但不幸的是我遇到了問題。

我的實作是:

func waitFun(wait int) chan int {
    time.Sleep(time.Duration(wait) * time.Second)

    c := make(chan int)
    c <- wait

    return c
}

func main() {
    c := make(chan int)
    go func() {
        time.Sleep(3 * time.Second)
        c <- 10
    }()

    select {
    case v := <-c:
        fmt.Println("Value v: ", v)
    case <-waitFun(1):
        fmt.Println("Timeout")
    }

    time.Sleep(4 * time.Second)
}
登入後複製

由於某種原因,這不起作用。錯誤是:all goroutine 正在休眠 - 死鎖! 。我知道在某個時刻,所有 goroutine(main 和用匿名函數引入的 goroutine)都會進入睡眠狀態,但這是錯誤的原因還是其他原因?我的意思是,這不是“無限睡眠”或“無限等待某事”,所以這不是死鎖,對吧?另外,使用 time.after 也會讓 goroutine 休眠,對嗎?我需要更改什麼才能使我的程式正常運作?

解決方法

select 語句將在運行時評估所有情況,因此此程式碼實際上會等待waitfun 返回,然後才開始偵聽任何通道。您必須更改 waitfun 以立即返回通道:

func waitFun(wait int) chan int {
    c := make(chan int)
    go func() {
       time.Sleep(time.Duration(wait) * time.Second)
       c <- wait
    }()
    return c
}
登入後複製

以上是為什麼我的自訂「超時等待頻道」不起作用以及如何使其起作用?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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