在我以前的文章中,我介绍了Scala Future and Promise。Future
代表一个异步计算,你可以设置你的回调函数或者利用Await.result
等待获取异步计算的结果,你还可以组合多个future
为一个新的future
。Promise
让你可以控制是否完成计算还是抛出异常,它的future
方法返回一个Future
对象,complete
、success
和failure
允许你完成计算。如果想要同步操作,可以使用Await.result
等待Future
完成或者超时,对于没有实现Awaitable
的代码块,可以使用blocking
方法实现同步执行。
以上是对上一篇文章的总结。Scala官方还提供了一个Async
库,用来简化Scala异步操作,尽管这个库还没有正式加入到Scala的标准库中。它是通过Scala macro
特性实现的。
async
用来标记一块异步执行的代码,通常这块代码中包含包含一个或者多个await
调用。如果没有await
调用,我们用future
方法就可以了。
这样,对于复杂的异步代码,你不必使用map
、flatMap
或者回调来实现复杂的多层的调用嵌套。
|
|
比如下面的代码,我们使用纯future
实现:
|
|
如果使用async/await
,代码将得到简化。
|
|
事实上,这个框架是SIP-22 - Async的参考实现。这个Scala特性提议发布于2013年。