package main
import "fmt"
func sum(s []int, c chan int) {
sum := 0
for _, v := range s {
sum += v
}
c <- sum // send sum to c
}
func main() {
s := []int{7, 2, 8, -9, 4, 0}
c := make(chan int)
go sum(s[:len(s)/2], c) //give 17
go sum(s[len(s)/2:], c) //give -5
x, y := <-c, <-c // receive from c
fmt.Println(x, y, x+y)
}
输出结果始终为-5 17 12
,这意味着第一个goroutine稳定地落后于第二个goroutine。正如我对多线程和通道的理解,结果的顺序在这个简单的上下文中应该是相反的。当goroutine的任务变得更复杂时,顺序应该是不可思议的。那么如何解释这个LIFO问题?