Channel

Channel是Go中的一個(gè)核心類(lèi)型,你可以把它看成一個(gè)管道,通過(guò)它并發(fā)核心單元就可以發(fā)送或者接收數(shù)據(jù)進(jìn)行通訊。
它的操作符是箭頭<-。

ch := make(chan int, 100)
defer close(ch)
ch <- v //發(fā)送值v到Channel ch中
v := <-ch //從Channel ch中接收數(shù)據(jù),并將數(shù)據(jù)賦值給v
v, ok := <-ch //可以檢查channel是否已經(jīng)被關(guān)閉
(箭頭的指向就是數(shù)據(jù)的流向)

使用make初始化Channel,可以設(shè)置容量,容量(capacity)代表channel容納的最多的元素?cái)?shù)量,代表channel的緩存的大小。如果沒(méi)有設(shè)置容量,或者設(shè)置容量為0,說(shuō)明Channel沒(méi)有緩存,只有sender和receiver都準(zhǔn)備好了后他們的通訊(communication)才會(huì)發(fā)生(Blocking)。如果設(shè)置了緩存,就有可能不發(fā)生阻塞,只有buffer滿了后send才會(huì)阻塞,而只有緩存空了后receive才會(huì)阻塞。

  • Channel類(lèi)型
    Channel類(lèi)型定義格式如下:
    ChannelType = ("chan" | "chan" "<-" | "<-" "chan")ElementType
    它包括三種類(lèi)型的定義。可選的<-代表channel的方向,如果沒(méi)有指定方向,那么channel就是雙向的。既可以接收數(shù)據(jù),也可以發(fā)送數(shù)據(jù)。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容