From 57f858dee9b33ae91a3c4ed8e9955be664b6c266 Mon Sep 17 00:00:00 2001 From: xin zhao Date: Tue, 22 May 2018 15:17:03 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E6=94=B9=2016.9=20=E7=AB=A0=E8=8A=82?= =?UTF-8?q?=E8=BE=93=E5=87=BA=E5=86=85=E5=AE=B9=E6=A0=BC=E5=BC=8F=20(#481)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 修改描述文字错误 --- eBook/16.9.md | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/eBook/16.9.md b/eBook/16.9.md index 6bb6b76..8800bf7 100644 --- a/eBook/16.9.md +++ b/eBook/16.9.md @@ -48,21 +48,21 @@ func main() { ``` -/* 输出: - - 0 1 2 3 4 +输出: - 4 4 4 4 4 +``` +0 1 2 3 4 - 1 0 3 4 2 +4 4 4 4 4 - 10 11 12 13 14 -*/ +1 0 3 4 2 -版本A调用闭包5次打印每个索引值,版本B也做相同的事,但是通过协程调用每个闭包。按理说这将执行得更快,因为闭包是并发执行的。如果我们阻塞足够多的时间,让所有协程执行完毕,版本B的输出是:`4 4 4 4 4`。为什么会这样?在版本B的循环中,`ix`变量 -实际是一个单变量,表示每个数组元素的索引值。因为这些闭包都只绑定到一个变量,这是一个比较好的方式,当你运行这段代码时,你将看见每次循环都打印最后一个索引值`4`,而不是每个元素的索引值。因为协程可能在循环结束后还没有开始执行,而此时`ix`值是`4`。 +10 11 12 13 14 +``` -版本C的循环写法才是正确的:调用每个闭包是将`ix`作为参数传递给闭包。`ix`在每次循环时都被重新赋值,并将每个协程的`ix`放置在栈中,所以当协程最终被执行时,每个索引值对协程都是可用的。注意这里的输出可能是`0 2 1 3 4`或者`0 3 1 2 4`或者其他类似的序列,这主要取决于每个协程何时开始被执行。 +版本A调用闭包5次打印每个索引值,版本B也做相同的事,但是通过协程调用每个闭包。按理说这将执行得更快,因为闭包是并发执行的。如果我们阻塞足够多的时间,让所有协程执行完毕,版本B的输出是:`4 4 4 4 4`。为什么会这样?在版本B的循环中,`ix`变量实际是一个单变量,表示每个数组元素的索引值。因为这些闭包都只绑定到一个变量,这是一个比较好的方式,当你运行这段代码时,你将看见每次循环都打印最后一个索引值`4`,而不是每个元素的索引值。因为协程可能在循环结束后还没有开始执行,而此时`ix`值是`4`。 + +版本C的循环写法才是正确的:调用每个闭包时将`ix`作为参数传递给闭包。`ix`在每次循环时都被重新赋值,并将每个协程的`ix`放置在栈中,所以当协程最终被执行时,每个索引值对协程都是可用的。注意这里的输出可能是`0 2 1 3 4`或者`0 3 1 2 4`或者其他类似的序列,这主要取决于每个协程何时开始被执行。 在版本D中,我们输出这个数组的值,为什么版本B不能而版本D可以呢?