Go語言中關閉帶緩沖區(qū)的頻道實例分析
本文實例分析了Go語言中關閉帶緩沖區(qū)的頻道。分享給大家供大家參考。具體分析如下:
Go語言提供了兩種頻道,帶緩沖區(qū)和不帶緩沖區(qū)的。不帶緩沖區(qū)的頻道,發(fā)送和接收是同步的,必須接收端接收了消息,發(fā)送端才能從發(fā)送調(diào)用中解脫。帶緩沖區(qū)的頻道,在緩沖區(qū)滿之前,發(fā)送和接收是異步的,發(fā)送端的發(fā)送操作只保證把消息放入緩沖區(qū)。
Go的頻道是可以關閉的,關閉頻道的目的是讓接收端知道不會再有消息從這個頻道進入,我們可能會用某個頻道的關閉來表示某種狀態(tài)的終結。
當我們關閉一個帶緩沖區(qū)的頻道時,如果緩沖區(qū)中還有消息,接收端是會繼續(xù)接收完剩余消息呢?還是直接就丟棄剩余消息呢?下面是我做的一個試驗代碼:
import "fmt"
func main() {
input := make(chan int, 10)
wait := make(chan int)
for i := 0; i < 10; i ++ {
input <- i
}
close(input)
go func() {
for {
if i, ok := <- input; ok {
fmt.Println(i)
} else {
break
}
}
wait <- 1
}()
<-wait
}
希望本文所述對大家的Go語言程序設計有所幫助。
相關文章
Go?runtime?調(diào)度器之系統(tǒng)調(diào)用引起的搶占
本文解析了在Go語言中,當goroutine執(zhí)行的系統(tǒng)調(diào)用時間過長時,系統(tǒng)如何通過監(jiān)控和搶占機制來處理,以維持運行效率和資源分配的平衡,通過具體的示例和流程圖,詳細展示了系統(tǒng)調(diào)用過程中的搶占操作,感興趣的朋友跟隨小編一起看看吧2024-09-09
Golang中println和fmt.Println區(qū)別解析
Golang 中打印數(shù)據(jù)通常使用 fmt.Println() 方法,也可以使用內(nèi)置的 println() 方法。這兩個方法大家可能都使用過,它們的區(qū)別是什么呢?本文給大家詳細講解,感興趣的朋友跟隨小編一起看看吧2023-03-03
Go語言異常處理(Panic和recovering)用法詳解
異常處理是程序健壯性的關鍵,往往開發(fā)人員的開發(fā)經(jīng)驗的多少從異常部分處理上就能得到體現(xiàn)。Go語言中沒有Try?Catch?Exception機制,但是提供了panic-and-recover機制,本文就來詳細講講他們的用法2022-07-07
golang?waitgroup輔助并發(fā)控制使用場景和方法解析
Golang?提供了簡潔的?go?關鍵字來讓開發(fā)者更容易的進行并發(fā)編程,同時也提供了?WaitGroup?對象來輔助并發(fā)控制,今天我們就來分析下?WaitGroup?的使用方法,順便瞧一瞧它的底層源碼2023-09-09
golang實現(xiàn)mysql數(shù)據(jù)庫事務的提交與回滾
這篇文章主要介紹了golang實現(xiàn)mysql數(shù)據(jù)庫事務的提交與回滾,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-04-04

