Skip to content

Commit 0c6b5cc

Browse files
committed
use Chinese punctuation
1 parent 7d194e2 commit 0c6b5cc

File tree

1 file changed

+7
-7
lines changed

1 file changed

+7
-7
lines changed

_zh-cn/tour/for-comprehensions.md

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -14,9 +14,9 @@ next-page: generic-classes
1414
previous-page: extractor-objects
1515
---
1616

17-
Scala 提供一个轻量级的标记方式用来表达 *序列推导*. 推导使用以下形式 `for (enumerators) yield e`, 此处 `enumerators` 指一组以分号分隔的迭代器. 一个 *enumerator* 要么是一个产生新变量的构造器, 要门是一个过滤器. 推导在循环的每一次迭代中都会计算 `e`, 并保存在集合中, 循环结束后返回该集合.
17+
Scala 提供一个轻量级的标记方式用来表达 *序列推导*推导使用以下形式 `for (enumerators) yield e`此处 `enumerators` 指一组以分号分隔的迭代器一个 *enumerator* 要么是一个产生新变量的构造器,要么是一个过滤器。推导在循环的每一次迭代中都会计算 `e`并保存在集合中循环结束后返回该集合
1818

19-
看下例:
19+
看下例
2020

2121
```tut
2222
case class User(name: String, age: Int)
@@ -31,9 +31,9 @@ val twentySomethings = for (user <- userBase if (user.age >=20 && user.age < 30)
3131
3232
twentySomethings.foreach(name => println(name)) // prints Travis Dennis
3333
```
34-
这里 `for` 循环后面使用的 `yield` 语句实际上会创建一个 `List`. 因为当我们说 `yield user.name` 的时候, 它实际上是一个 `List[String]`. `user <- userBase` 是循环迭代器, `if (user.age >=20 && user.age < 30)` 是循环守卫用来过滤掉那些年龄不是20多岁的人.
34+
这里 `for` 循环后面使用的 `yield` 语句实际上会创建一个 `List`因为当我们说 `yield user.name` 的时候它实际上是一个 `List[String]` `user <- userBase` 是循环迭代器`if (user.age >=20 && user.age < 30)` 是循环守卫用来过滤掉那些年龄不是20多岁的人
3535

36-
下面这个例子复杂一些, 使用了两个迭代器. 它计算了 `0``n-1` 的所有两两求和为 `v` 的数字的组合:
36+
下面这个例子复杂一些使用了两个迭代器它计算了 `0``n-1` 的所有两两求和为 `v` 的数字的组合
3737

3838
```tut
3939
def foo(n: Int, v: Int) =
@@ -47,15 +47,15 @@ foo(10, 10) foreach {
4747
}
4848
4949
```
50-
这里 `n == 10``v == 10`. 在第一次迭代时, `i == 0` 并且 `j == 0` 所以 `i + j != v` 因此没有返回值被生成. `i` 的值递增到 `1` 之前, `j` 的值又递增了 9 次. 如果没有 `if` 守护语句, 上面的例子只会打印出如下的结果:
50+
这里 `n == 10``v == 10`在第一次迭代时`i == 0` 并且 `j == 0` 所以 `i + j != v` 因此没有返回值被生成`i` 的值递增到 `1` 之前`j` 的值又递增了 9 次如果没有 `if` 守护语句上面的例子只会打印出如下的结果
5151
```
5252
5353
(0, 0) (0, 1) (0, 2) (0, 3) (0, 4) (0, 5) (0, 6) (0, 7) (0, 8) (0, 9) (1, 1) ...
5454
```
5555

56-
注意推导并不局限于使用列表. 任何数据类型只要支持 `withFilter`, `map`, `flatMap` 操作 (不同数据类型可能支持不同的操作) 都可以用来做序列推导.
56+
注意推导并不局限于使用列表任何数据类型只要支持 `withFilter``map``flatMap` 操作不同数据类型可能支持不同的操作都可以用来做序列推导
5757

58-
你可以在使用推导时省略 `yield` 语句. 此时推导会返回 `Unit`. 当你想要执行一些副作用的时候这很有用. 下面的例子输出和上面相同的结果, 但是没有使用 `yield`:
58+
你可以在使用推导时省略 `yield` 语句此时推导会返回 `Unit`当你想要执行一些副作用的时候这很有用下面的例子输出和上面相同的结果但是没有使用 `yield`
5959

6060
```tut
6161
def foo(n: Int, v: Int) =

0 commit comments

Comments
 (0)