For Comprehensions

来源:互联网 发布:淘宝助理没有安能物流 编辑:程序博客网 时间:2024/06/07 03:30
For Comprehensions
由于 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,然后对其进行组合的情况下才能得到真正的好处。
0 0