scala的Promise和Future的理解
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了scala的Promise和Future的理解相关的知识,希望对你有一定的参考价值。
scala版本:2.11
在scala的并发包下存在2个类Promise和Future。用起来很简单。例子如下:
import scala.concurrent.ExecutionContext.Implicits.global
import scala.concurrent.{Future, Promise}
object PromiseAndFuture extends App {
// 小李:等你到上海了,打电话告诉我
val tellMe = Promise[String]()
val result = tellMe.future
result.recover {
case CannotArriveException(msg) => msg
}.foreach(msg => {
println(s"接电话:$msg")
println("小李:好,立刻去接他。")// 小李自己的任务
})
xiaoZhangTask()
println("小李:逛街中。。。")
Thread.sleep(5000) // 防止线程直接退出
private def xiaoZhangTask() = {
Future {
println("小张:从北京出发了。")
Thread.sleep(2000) // 一直在路上
println("小张:已经到上海了,该告诉小李了。")
tellMe.success("我是小张,我已经到上海了。")
}.recover {
case _: Throwable =>
println("小张:我迷路了,该告诉小李了。")
tellMe.failure(CannotArriveException("我是小张,我找不到上海怎么办?"))
}
}
}
case class CannotArriveException(msg: String) extends Exception(msg)
控制台输入如下:
小张:从北京出发了。
小李:逛街中。。。
小张:已经到上海了,该告诉小李了。
接电话:我是小张,我已经到上海了。
小李:好,终于可以见到他了。
- Promise字面意思为“许可”,当你向让另外一个人(另外一个线程)去做某件事,并且需要该事情的结果,你需要先“许可”对方可以告诉你的结果(成功/失败,成功是什么或者失败的原因是什么)。
- Future字面意思为“未来”,表示未来发生的结果,这个结果可关心可不关心。如果关心可使用
map
或onComplete
或recover
等方法来处理。
结论:在异步转同步时Promise非常好用。其他情况再具体分析是否要用Promise,大部分情况直接使用Future就比较简单。
以上是关于scala的Promise和Future的理解的主要内容,如果未能解决你的问题,请参考以下文章
Js Deferred/Promise/Future 与 Scala 等函数式语言相比
[转] Scala Async 库 (Scala future, await, async)