```golang
package main
import (
"fmt"
)
func loop(silice []int, c chan int, res string) {
sum := 0
for _, v := range silice {
sum += v
}
c <- sum
fmt.Println(res, "---sum:", sum)
}
func main() {
c := make(chan int)
arr := []int{1, 2, 3, 4, 5, 6}
go loop(arr[:len(arr)/2], c, "first loop")
go loop(arr[len(arr)/2:len(arr)], c, "second loop")
x, y := <-c, <-c
fmt.Println("x,y,x+y:", x, y, x+y)
}
```
输出结果为
first loop ---sum: 6
x,y,x+y: 6 15 21
起的函数名称不恰当。。。改的代码
为什么只会输出first,而不输出second,当执行两个go的时候,按说两个loop函数都会被挂起(阻塞),在主线执行时,第一个loop和第二个分别解除阻塞,那么为什么只有第一个loop 最后的print被输出,而第二个没有。
我的理解是,如果主线获取channel的取值后,他的过程是什么,是完成之前被阻塞的线程goroutine(那么 first和second都会被执行)?还是不再跳回之前的线程,继续然后执行主线(那么first和second 的两个输出应该都不会被执行)
可是现在输出了一个,只有first,让我有些费解,请个位同学赐教
这就是我的问题,main和loop是在同时执行的么,因为如果是同时执行,那么我可以理解。对不起,我对并性刚开始接触。通过我对并性和并发的理解。这里面在执行loop和在执行main的时候,同一时间只有一个在执行,那么当从main中跳转到第二个loop的时候,main应该是挂起的,也就是或不应该会出现main执行结束而第二个loop没有执行完啊。
#4
更多评论
算上main是有三个go协程。第一次获得数据会正常输出。然后main取出管道中值,
第二次main接到管道中的数据后main直接结束。第二个函数里的输出语句即将打印但还没有打印。
这时候main退出会导致第二个协程死掉。所以就看不到输出了。
#1
这段代码,如去掉 x, y := <-c, <-c,则任何 goroutine 都不会执行就退出了。
这段代码,如加上 runtime.GOMAXPROC(2)调度到两个 core 上,又不一样。
不觉得有什么异常呀?
#2