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

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

转载于:https://blog.51cto.com/5705145/2318670

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值