Go語言使用goroutine及通道實現(xiàn)并發(fā)詳解
使用通道接收數(shù)據(jù)
在上一篇文章中介紹了通道以及使用通道發(fā)送數(shù)據(jù),本篇接著了解通道的基本內(nèi)容,如何使用通道接收數(shù)據(jù);
通道的接收同樣使用"<-"操作符;
使用通道接收數(shù)據(jù)的特性如下:
- 通道的發(fā)送和接收操作在不同的兩個goroutine間進(jìn)行,由于通道中的數(shù)據(jù)在沒有接收方接收時會持續(xù)阻塞,所以通道的接收必定在另外一個goroutine中進(jìn)行;
- 如果在接收方接收時,通道中沒有發(fā)送方發(fā)送數(shù)據(jù),則接收方也會發(fā)生阻塞,直到發(fā)送方發(fā)送消息為止;
- 通道一次只能接收一個元素數(shù)據(jù);
通道的數(shù)據(jù)接收有四種寫法,接下來一一進(jìn)行介紹
阻塞接收數(shù)據(jù)
阻塞模式在接收數(shù)據(jù)時,將接收變量作為"<-"操作符的左值,格式如下:
data := <-ch
執(zhí)行該語句時將會阻塞,直到接收到數(shù)據(jù)并賦值給data變量
非阻塞接收數(shù)據(jù)
在使用非阻塞方式從通道接收數(shù)據(jù)時,語句不會發(fā)生阻塞,格式如下
data, ok := <-ch
data:接收到的數(shù)據(jù),在未接收到數(shù)據(jù)時data為通道類型的零值
ok:是否接收到數(shù)據(jù)
非阻塞的通道接收方法,可能造成高的CPU占用,因此使用非常少,如果需要實現(xiàn)接收超時檢測,則需要配合select和計時器進(jìn)行;
接收任意數(shù)據(jù),忽略掉接收的數(shù)據(jù)
寫法如下:
<-ch
使用上面的這種寫法,會發(fā)生阻塞,直到接收到消息,但是通道在接收到數(shù)據(jù)后會將其忽略掉;這個方式實際上只是通過通道在goroutine間阻塞收發(fā),從而實現(xiàn)并發(fā)同步;
使用通道做并發(fā)同步的示例如下圖所示:
循環(huán)接收數(shù)據(jù)
通道的數(shù)據(jù)接收可以借用for-range語句進(jìn)行多個元素的接收操作,格式如下:
for data := range ch{ }
通道ch是可以被遍歷的,遍歷的結(jié)果就是接收到的數(shù)據(jù),數(shù)據(jù)類型就是通道的數(shù)據(jù)類型,通過for遍歷獲得的變量只有一個,即上面例子中的data;
遍歷通道數(shù)據(jù)的示例如下圖所示:
通道可以在兩個goroutine之間通過傳遞一個指定類型的值來同步運行和通訊,操作符"<-"用于指定通道的方向、發(fā)送和接收,如果未指定方向,則為雙向通道;
ch <- v 把v發(fā)送到通道ch中
v := <-ch 從ch接收數(shù)據(jù),并把值賦給v
下面列舉一個示例通過兩個goroutine計算數(shù)字之和,如下圖所示:
以上就是通道接收數(shù)據(jù)的相關(guān)內(nèi)容,更多關(guān)于Go goroutine通道并發(fā)的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Golang?Redis連接池實現(xiàn)原理及示例探究
這篇文章主要為大家介紹了Golang?Redis連接池實現(xiàn)示例探究,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2024-01-01以Golang為例詳解AST抽象語法樹的原理與實現(xiàn)
AST?使用樹狀結(jié)構(gòu)來表達(dá)編程語言的結(jié)構(gòu),樹中的每一個節(jié)點都表示源碼中的一個結(jié)構(gòu),本文將以GO語言為例,為大家介紹一下AST抽象語法樹的原理與實現(xiàn),希望對大家有所幫助2024-01-01