考虑以下代码段:
class MyClass {
var a = _
var b = _
...
var y = _
val z = (for {
a0 <- someMethodReturningFuture
b0 <- someMethodReturningFuture(a0)
...
z0 <- someMethodReturningFuture(y0)
} yield {
a = a0
b = b0
...
y = y0
someCalculation(y)
}).result
}
是否可以执行此类初始化但使用val
而不是var
s(以某种方式)?关键是,我不想阻止并等待每个中间结果,只是为了最后一个。
答案 0 :(得分:6)
除非您有超过22个变量:
val (a, b, c, d, ..., v) = (for {
a0 <- someMethodReturningFuture
b0 <- someMethodReturningFuture(a0)
...
u0 <- someMethodReturningFuture(t0)
} yield {
(a0, b0, ..., u0, someCalculation(u0))
}).result
答案 1 :(得分:3)
您可以使用result
值延迟lazy
评估吗?类似的东西:
class MyClass {
lazy val a = myFutures.a.result
lazy val b = myFutures.b.result
private val myFutures = new AnyRef {
val a = someMethodReturningFuture
val b = a.map( a0 => someMethodReturningFuture(a0) )
}
}
所有期货都是在初始化时创建的,没有阻止,但是当您第一次尝试使用结果时,您将阻止。