修改 16.9 章节输出内容格式 (#481)

修改描述文字错误
This commit is contained in:
xin zhao
2018-05-22 15:17:03 +08:00
committed by 无闻
parent 467777b5c0
commit 57f858dee9

View File

@@ -48,8 +48,9 @@ func main() {
``` ```
/* 输出: 输出:
```
0 1 2 3 4 0 1 2 3 4
4 4 4 4 4 4 4 4 4 4
@@ -57,12 +58,11 @@ func main() {
1 0 3 4 2 1 0 3 4 2
10 11 12 13 14 10 11 12 13 14
*/ ```
版本A调用闭包5次打印每个索引值版本B也做相同的事但是通过协程调用每个闭包。按理说这将执行得更快因为闭包是并发执行的。如果我们阻塞足够多的时间让所有协程执行完毕版本B的输出是`4 4 4 4 4`。为什么会这样在版本B的循环中`ix`变量 版本A调用闭包5次打印每个索引值版本B也做相同的事但是通过协程调用每个闭包。按理说这将执行得更快因为闭包是并发执行的。如果我们阻塞足够多的时间让所有协程执行完毕版本B的输出是`4 4 4 4 4`。为什么会这样在版本B的循环中`ix`变量实际是一个单变量,表示每个数组元素的索引值。因为这些闭包都只绑定到一个变量,这是一个比较好的方式,当你运行这段代码时,你将看见每次循环都打印最后一个索引值`4`,而不是每个元素的索引值。因为协程可能在循环结束后还没有开始执行,而此时`ix`值是`4`
实际是一个单变量,表示每个数组元素的索引值。因为这些闭包都只绑定到一个变量,这是一个比较好的方式,当你运行这段代码时,你将看见每次循环都打印最后一个索引值`4`,而不是每个元素的索引值。因为协程可能在循环结束后还没有开始执行,而此时`ix`值是`4`
版本C的循环写法才是正确的调用每个闭包`ix`作为参数传递给闭包。`ix`在每次循环时都被重新赋值,并将每个协程的`ix`放置在栈中,所以当协程最终被执行时,每个索引值对协程都是可用的。注意这里的输出可能是`0 2 1 3 4`或者`0 3 1 2 4`或者其他类似的序列,这主要取决于每个协程何时开始被执行。 版本C的循环写法才是正确的调用每个闭包`ix`作为参数传递给闭包。`ix`在每次循环时都被重新赋值,并将每个协程的`ix`放置在栈中,所以当协程最终被执行时,每个索引值对协程都是可用的。注意这里的输出可能是`0 2 1 3 4`或者`0 3 1 2 4`或者其他类似的序列,这主要取决于每个协程何时开始被执行。
在版本D中我们输出这个数组的值为什么版本B不能而版本D可以呢 在版本D中我们输出这个数组的值为什么版本B不能而版本D可以呢