介绍:
我刚刚开始学习 Go 语言,并且已经上过关于并发的课程。
我为自己发明了一个小任务来尝试实现我所学到的关于关闭 goroutines 的知识。
问题:
如果我们关闭通道,case
它将始终在select
语句中被选中,这是向所有 goroutine 广播取消信号的好方法。
下面我有 2 个 goroutine 和一个quit
永远不会收到的频道。
Playground上的代码超时。
default
如果我在 goroutines 中注释掉部分,那么quit
就会收到信号。
问题:
尽管我正在尝试,但我真的不明白为什么会发生这种情况以及如何解决它。
有人可以解释一下是什么问题并就如何解决它提供一些建议吗?
package main
import (
"fmt"
"sync"
"time"
)
func positive_numbers(quit chan struct{}, wg *sync.WaitGroup) {
defer wg.Done()
i := 1
for {
select {
case <-quit:
fmt.Println("[+]Quiting...")
return
default:
fmt.Printf("%v ", i)
i++
}
}
}
func negative_numbers(quit chan struct{}, wg *sync.WaitGroup) {
defer wg.Done()
i := -1
for {
select {
case <-quit:
fmt.Println("[-]Quiting...")
return
default:
fmt.Printf("%v ", i)
i--
}
}
}
func main() {
quit := make(chan struct{})
wg := sync.WaitGroup{} // so we can wait for all goroutines to finish
wg.Add(2)
go positive_numbers(quit, &wg)
go negative_numbers(quit, &wg)
go func(quit chan struct{}) {
defer close(quit)
time.Sleep(1 * time.Second)
}(quit)
wg.Wait()
}