```
package main
import (
"fmt"
"time"
)
func main() {
limiter := make(chan bool, 10)
for i := 0; i < 100; i++ {
limiter <- true
go download(i, limiter)
}
}
func download(index int, limiter chan bool) {
time.Sleep(1 * time.Second)
fmt.Println("start to download :", index)
<-limiter
}
```
上面这段代码执行结果为什么最大打印值直到 89 ?
当把
```
time.Sleep(1 * time.Second)
fmt.Println("start to download :", index)
```
两行上下调换之后,变成以下的代码:
```
fmt.Println("start to download :", index)
time.Sleep(1 * time.Second)
```
就能正常打印到 99 了?
嗯,确实如此,感觉不论后续是否有其他操作( 除 `sleep` 强制等待 和 `range channel` 阻塞 之外),如果在 main 中新开 `goroutinue `去`wg.wait`的话,都会有可能会导致` main` 比 负责` wait` 的 `goroutinue` 提前结束。
#25
更多评论
问题的关键在于 main goroutine 提前退出了。
不论是那种代码,最好在 main 函数最后等待所有 goroutine 执行完成,方法很多了,可以 Sleep,可以 sync.WaitGroup 等等。
#1