For Comprehensions

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,然后对其进行组合的情况下才能得到真正的好处。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值