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 错误,因为生产者消费者问题的详细内容。更多信息请关注PHP中文网其他相关文章!