package main
import (
"fmt"
"runtime"
)
func task(q int,c chan int) {
// 模拟耗时操作
fmt.Println("starting heavy_task")
for i := 0;i < q;i++{
c <- i
time.Sleep(800 * time.Millisecond)
}
fmt.Println("Done heavy_task")
}
func main() {
// 利用chan来同步代码
var cores = runtime.NumCPU()
res := make([]int,cores)
c := make(chan int,cores)
go task(cores,c)
for i := 0; i < cores; i++ {
fmt.Println("waiting data...")
res[i] = <-c
fmt.Println("received data->",res[i])
}
fmt.Println("res->",res)
}
输出:
请问heavy_task函数中最后一句“Done heavy_task”为啥没有打印出来呢?
有疑问加站长微信联系(非本文作者)

因为最后一次执行time.Sleep(800 * time.Millisecond)时,主进程已经执行完成了,整个程序就提前结束了。 你可以在主进程最后也用time.Sleep()来等待一下task()执行完,或者使用sync.WaitGroup来等待go并发执行完成。
协程还在sleep,而主线程就已经退出了
谢谢!明白了!
多谢啦!