Go語(yǔ)言利用time.After實(shí)現(xiàn)超時(shí)控制的方法詳解
前言
在開(kāi)始之前,對(duì)time.After使用有疑問(wèn)的朋友們可以看看這篇文章:http://www.dbjr.com.cn/article/146063.htm
我們?cè)贕olang網(wǎng)絡(luò)編程中,經(jīng)常要遇到設(shè)置超時(shí)的需求,本文就來(lái)給大家詳細(xì)介紹了Go語(yǔ)言利用time.After實(shí)現(xiàn)超時(shí)控制的相關(guān)內(nèi)容,下面話不多說(shuō)了,來(lái)一起看看詳細(xì)的介紹吧。
場(chǎng)景:
假設(shè)業(yè)務(wù)中需調(diào)用服務(wù)接口A,要求超時(shí)時(shí)間為5秒,那么如何優(yōu)雅、簡(jiǎn)潔的實(shí)現(xiàn)呢?
我們可以采用select+time.After的方式,十分簡(jiǎn)單適用的實(shí)現(xiàn)。
首先,我們先看time.After()
源碼:
// After waits for the duration to elapse and then sends the current time // on the returned channel. // It is equivalent to NewTimer(d).C. // The underlying Timer is not recovered by the garbage collector // until the timer fires. If efficiency is a concern, use NewTimer // instead and call Timer.Stop if the timer is no longer needed. func After(d Duration) <-chan Time { return NewTimer(d).C }
time.After()
表示time.Duration
長(zhǎng)的時(shí)候后返回一條time.Time類(lèi)型的通道消息。那么,基于這個(gè)函數(shù),就相當(dāng)于實(shí)現(xiàn)了定時(shí)器,且是無(wú)阻塞的。
超時(shí)控制的代碼實(shí)現(xiàn):
package main import ( "time" "fmt" ) func main() { ch := make(chan string) go func() { time.Sleep(time.Second * 2) ch <- "result" }() select { case res := <-ch: fmt.Println(res) case <-time.After(time.Second * 1): fmt.Println("timeout") } }
我們使用channel來(lái)接收協(xié)程里的業(yè)務(wù)返回值。
select語(yǔ)句阻塞等待最先返回?cái)?shù)據(jù)的channel,當(dāng)先接收到time.After
的通道數(shù)據(jù)時(shí),select則會(huì)停止阻塞并執(zhí)行該case的代碼。此時(shí)就已經(jīng)實(shí)現(xiàn)了對(duì)業(yè)務(wù)代碼的超時(shí)處理。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
Go?Error?嵌套實(shí)現(xiàn)創(chuàng)建方式
這篇文章主要介紹了Go?Error?嵌套到底是怎么實(shí)現(xiàn)的?大家都知道創(chuàng)建error有兩種方式分別是errors.new()另一種是fmt.errorf(),本文通過(guò)詳細(xì)例子給大家介紹,需要的朋友可以參考下2022-01-01Go語(yǔ)言實(shí)現(xiàn)對(duì)稱(chēng)加密和非對(duì)稱(chēng)加密的示例代碼
本文主要介紹了Go語(yǔ)言實(shí)現(xiàn)對(duì)稱(chēng)加密和非對(duì)稱(chēng)加密的示例代碼,通過(guò)實(shí)際代碼示例展示了如何在Go中實(shí)現(xiàn)這兩種加密方式,具有一定的參考價(jià)值,感興趣的可以了解一下2024-01-01GoFrame?gmap遍歷hashmap?listmap?treemap使用技巧
這篇文章主要為大家介紹了GoFrame?gmap遍歷hashmap?listmap?treemap使用技巧的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-06-06Golang函數(shù)重試機(jī)制實(shí)現(xiàn)代碼
在編寫(xiě)應(yīng)用程序時(shí),有時(shí)候會(huì)遇到一些短暫的錯(cuò)誤,例如網(wǎng)絡(luò)請(qǐng)求、服務(wù)鏈接終端失敗等,這些錯(cuò)誤可能導(dǎo)致函數(shù)執(zhí)行失敗,這篇文章主要介紹了Golang函數(shù)重試機(jī)制實(shí)現(xiàn)代碼,需要的朋友可以參考下2024-04-04Go 標(biāo)準(zhǔn)庫(kù)增加metrics指標(biāo)探討分析
go中有一個(gè)神奇的標(biāo)準(zhǔn)庫(kù) runtime/metrics,提供了一系列預(yù)定義好的 Go 自身的相關(guān)指標(biāo),如果沒(méi)有編寫(xiě)過(guò)基礎(chǔ)監(jiān)控庫(kù)或者關(guān)注的比較少的朋友可能會(huì)沒(méi)接觸到這類(lèi)指標(biāo),本文展開(kāi)現(xiàn)有metrics 指標(biāo),并結(jié)合現(xiàn)有的社區(qū)討論一起看看還有沒(méi)有必要增加更多的標(biāo)準(zhǔn)庫(kù)指標(biāo)2023-10-10