php小编柚子在解决编程问题时,可能会遇到一个常见的错误提示:“goroutines are sleeped”。这个错误通常与生产者消费者问题有关。生产者消费者问题是并发编程中的一种经典情景,其中一个或多个生产者生成数据,而一个或多个消费者从中取出数据进行处理。当生产者生成数据的速度超过消费者处理数据的速度时,就可能导致goroutines(Go语言中的轻量级线程)进入休眠状态。本文将解释为什么会出现这个错误,并提供解决方法。
问题内容
这是代码 - go 例程中的生产者和多个消费者。 生产者正在向一个通道注入信息,多个消费者(每个消费者通过一个 go-routine)应该并行读取它。
func main() {
alphabetArray := []string{"A", "B", "C"}
alphabetChannel := make(chan string, 3)
// producer.
go func() {
for _, alphabet := range alphabetArray {
alphabetChannel <- alphabet
}
}()
var wg sync.WaitGroup
// spawn 10 consumers, consumers represented as a go-routine.
for idx := 0; idx < 10; idx++ {
wg.Add(1)
go func() {
for alphabet := range alphabetChannel {
fmt.Println(alphabet)
}
}()
}
wg.Wait()
}
这是去游乐场的链接 - https://go.dev/play/p/yndataeexpb
我收到的错误是这样的 -
一个 乙 c 致命错误:所有 goroutine 都在睡觉 - 死锁!
解决方法
生产者完成后关闭通道,以便消费者知道何时停止:
go func() {
defer close(alphabetchannel)
for _, alphabet := range alphabetarray {
alphabetchannel <- alphabet
}
}()
让等待组知道消费者何时完成:
go func() {
defer wg.Done()
for alphabet := range alphabetChannel {
fmt.Println(alphabet)
}
}()
以上就是为什么我会收到 - goroutines are sleeped 错误,因为生产者消费者问题的详细内容,更多请关注编程网其它相关文章!