For Comprehensions
由于 Future 拥有 map, filter 和 flatMap 方法,它可以方便地用于 ‘for comprehension’:
// 注意future a, b, c
// 不是并发执行的
val result = Await.result(f, 1 second)
result must be(24)
做这些事情的时候需要记住的是:虽然看上去上例的部分代码可以并发地运行,for comprehension的每一步是顺序执行的。每一步是在单独的线程中运行的,但是相较于将所有的计算在一个单独的 Future中运行并没有太大好处. 只有在先(译者注:异步地)创建 Future,然后对其进行组合的情况下才能得到真正的好处。
由于 Future 拥有 map, filter 和 flatMap 方法,它可以方便地用于 ‘for comprehension’:
val f = for {
a ← Future(10 / 2) // 10 / 2 = 5
b ← Future(a + 1) // 5 + 1 = 6
c ← Future(a - 1) // 5 - 1 = 4
if c > 3 // Future.filter
} yield b * c // 6 * 4 = 24
// 注意future a, b, c
// 不是并发执行的
val result = Await.result(f, 1 second)
result must be(24)
做这些事情的时候需要记住的是:虽然看上去上例的部分代码可以并发地运行,for comprehension的每一步是顺序执行的。每一步是在单独的线程中运行的,但是相较于将所有的计算在一个单独的 Future中运行并没有太大好处. 只有在先(译者注:异步地)创建 Future,然后对其进行组合的情况下才能得到真正的好处。