Go 采用 time.After 实现超时控制
生活随笔
收集整理的這篇文章主要介紹了
Go 采用 time.After 实现超时控制
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
場景:
假設業務中需調用服務接口A,要求超時時間為5秒,那么如何優雅、簡潔的實現呢?我們可以采用select+time.After的方式,十分簡單適用的實現。time.After()表示time.Duration長的時候后返回一條time.Time類型的通道消息。那么,基于這個函數,就相當于實現了定時器,且是無阻塞的。超時控制的代碼實現:
package mainimport ("fmt""time"
)func main() {ch := make(chan string)go func() {fmt.Println("go func start....")time.Sleep(time.Second * 2)ch <- "result"}()select {//第一個case里阻塞的時間只有比第二個case阻塞的時間長的時候, 才能執行第二個casecase res := <-ch:fmt.Println(res)case <-time.After(time.Second * 1):fmt.Println("timeout")}
}我們使用channel來接收協程里的業務返回值。
select語句阻塞等待最先返回數據的channel,當先接收到time.After的通道數據時,select則會停止阻塞并執行該case的代碼。此時就已經實現了對業務代碼的超時處理。
轉載于:https://www.cnblogs.com/nyist-xsk/p/11302743.html
總結
以上是生活随笔為你收集整理的Go 采用 time.After 实现超时控制的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 富文本器的选择
- 下一篇: TinyMCE的使用