Go并发编程中通道数据接收顺序并非Goroutine启动顺序的解析
Go语言中的通道(channel)是Goroutine间高效通信的关键机制。本文将分析一段Go代码,解释为何从通道接收数据的顺序与Goroutine启动顺序不一致。
这段代码展示了两个Goroutine分别计算切片不同部分的和,并将结果发送到同一个通道,主Goroutine最后接收结果。代码如下:
package mainimport "fmt"func sum(s []int, c chan int) { sum := 0 for _, v := range s { sum += v } c <- sum // 将计算结果发送到通道c}func main() { a := []int{7, 2, 8, -9, 4, 0} c := make(chan int) go sum(a[:len(a)/2], c) // 启动Goroutine 1,计算前一半切片的和 go sum(a[len(a)/2:], c) // 启动Goroutine 2,计算后一半切片的和 x, y := <-c, <-c // 从通道c接收两个结果 fmt.Println(x, y, x+y) // 打印结果}
登录后复制
代码中,x, y := 同步机制,例如WaitGroup或锁。
为了更清晰地说明,可以将代码修改为打印Goroutine的ID:
package mainimport ( "fmt" "runtime")func sum(s []int, c chan int) { sum := 0 for _, v := range s { sum += v } c <- sum}func main() { a := []int{7, 2, 8, -9, 4, 0} c := make(chan int) go func() { fmt.Println("Goroutine 1 ID:", runtime.GoID()) sum(a[:len(a)/2], c) }() go func() { fmt.Println("Goroutine 2 ID:", runtime.GoID()) sum(a[len(a)/2:], c) }() x, y := <-c, <-c fmt.Println(x, y, x+y)}
登录后复制
运行此修改后的代码,可以观察到Goroutine ID与接收到的结果顺序并不一致,从而更直观地理解通道接收的非确定性。
以上就是Go并发编程中,通道接收数据的顺序为什么不是goroutine启动的顺序?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2306820.html