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中文網其他相關文章!