日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Go Concurrency Patterns: Timing out, moving on

發布時間:2024/7/23 编程问答 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Go Concurrency Patterns: Timing out, moving on 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原文地址:https://blog.golang.org/concurrency-timeouts

并發變成有它自己的風格. 一個非常好的例子就是 timeout. 雖然 go 的 channel 沒有直接支持 timeout 機制,但是要實現它非常容易.

比如說,我們想從一個 channel ch 中接收數據,但是最多只想等待 1 秒. 我們可以這么做:創建一個 channel 作為信號 channel (signalling channel), 再創建一個 goroutine,這個 goroutine 再發送數據之前先休眠 1 秒.

timeout := make(chan bool, 1) go func() {time.Sleep(1 * time.Second)timeout <- true }()

然后,我們使用 select 語句來從 ch 上接受數據. 如果在 1 秒之后,ch 上沒有數據到來,那么我們將會進入timeout 分支.

select { case <-ch:// a read from ch has occurred case <-timeout:// the read from ch has timed out }

timeout channel 的 buffer 大小為 1, 當 goroutine 發送了 timeout 信號之后,便退出了. goroutine 并不知道它發送的超時信號是否已經被接受,這意味著,如果 在 1秒之內,成功的從 ch 上收到了數據, goroutine 不會因為等待它發送到 timeout channel 上的信號被接受而永遠阻塞.

接下來,我們來看一下這個模式的一種變體. 在這個例子中,我們的程序從多個數據庫中同時讀取數據. 它僅僅需要一個結果,因此它只會接收最先到達的數據.

Query 輸入一個數據庫連接的集合和一個查詢字符串,它會同時查詢這些數據庫,接收第一個查詢結果.

func Query(conns []Conn, query string) Result {ch := make(chan Result)for _, conn := range conns {go func(c Conn) {select {case ch <- c.DoQuery(query):default:}}(conn)}return <-ch }

這個方法中,我們為每個數據庫查詢操作開啟一個 goroutine,在 goroutine 中以非阻塞模式返送請求,等待查詢結果. 為每個數據庫連接使用一個單獨 goroutine 確保了一個操作不會影響另一個操作,這些操作并行進行.

END!!!

總結

以上是生活随笔為你收集整理的Go Concurrency Patterns: Timing out, moving on的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。