我正在嘗試重新實(shí)現(xiàn)/修改這篇文章的第二條評(píng)論的代碼。我想要多個(gè) go 例程從堆棧中彈出元素(只要堆棧包含某些內(nèi)容),并使用另一個(gè)函數(shù)來(lái)捕獲它們。func pop(list *[]int, c chan int) { if len(*list) != 0 { result := (*list)[0] *list = (*list)[1:] fmt.Println("about to send ",result) c <- result } else {return}}func receiver (c chan int){ result := <- c fmt.Println("received ", result)}var list = []int{1, 2, 3}func main() {fmt.Println("Main")c := make(chan int)go pop (&list, c)go pop (&list,c)receiver(c)fmt.Scan()如果我使receiver(c) 成為一個(gè)go 例程,則只會(huì)打印“Main”,并且程序?qū)⑼顺龆坏却齋can() 函數(shù)。即使添加 time.Sleep(2) 也不會(huì)阻止程序退出。為什么我的程序在沒(méi)有任何輸入的情況下退出?
1 回答

慕婉清6462132
TA貢獻(xiàn)1804條經(jīng)驗(yàn) 獲得超2個(gè)贊
Scan 如果給定零個(gè)參數(shù),則不會(huì)阻塞。
請(qǐng)注意,即使您給它一個(gè)參數(shù),Playground 也不會(huì)阻塞 IO,代碼
var i int
fmt.Scan(&i)
也將無(wú)法阻止,如果您檢查error它返回的值(第二個(gè)返回值),您應(yīng)該檢查它,您將看到它報(bào)告error: EOF。
(盡管該樣本會(huì)在 Playground 之外被阻擋)。
編輯:如果您想在不創(chuàng)建虛擬變量的情況下阻止輸入,請(qǐng)使用Scanln,盡管它仍然會(huì)在操場(chǎng)上失敗。
- 1 回答
- 0 關(guān)注
- 206 瀏覽
添加回答
舉報(bào)
0/150
提交
取消