2 回答

TA贡献1818条经验 获得超3个赞
您无需等待 中的两个“非工作”goroutine main
,因此一旦wg.Wait()
返回,进程就会关闭,并拆除所有未完成的 goroutine。
由于其中一个正在处理结果,因此在您看来,好像并非所有任务都已处理(这是真的)。

TA贡献1817条经验 获得超6个赞
工作人员完成后关闭结果通道。在主 goroutine 中处理结果。
wg := sync.WaitGroup{}
for i := 1; i < 1000; i++ {
wg.Add(1)
go worker(&wg)
}
go func() {
for i := 1; i < 65535; i++ {
jobs <- Job{host, i}
}
// No more jobs, exit from worker loops.
close(jobs)
// Wait for workers to write all results and exit.
wg.Wait()
// No more results, exit from main loop.
close(results)
}()
for result := range results {
if result.status {
fmt.Println(result.job, "open")
}
}
- 2 回答
- 0 关注
- 134 浏览
添加回答
举报