温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

scala的Promise和Future的理解

发布时间:2020-06-22 10:24:38 来源:网络 阅读:1423 作者:53422245 栏目:开发技术

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字面意思为“未来”,表示未来发生的结果,这个结果可关心可不关心。如果关心可使用maponCompleterecover等方法来处理。

结论:在异步转同步时Promise非常好用。其他情况再具体分析是否要用Promise,大部分情况直接使用Future就比较简单。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI