scala的Promise和Future的理解
admin
2023-07-26 11:40:07
0

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就比较简单。

相关内容

热门资讯

以色列防长称以伊可能随时再起冲... △卡茨(资料图)据以色列方面29日消息,以国防部长卡茨当天表示,鉴于复杂的安全局势和在黎巴嫩的军事行...
零售门店会员激活与5G视频触达... 导语:据2025年行业白皮书数据显示,国内AI语音呼叫市场近三年复合增长率达32.7%,2026年市...
存量商办“变”医院!深圳探索公... 深圳商报·读创客户端首席记者 李秀瑜 深圳存量资产盘活跑出新模式。 6月27日,深圳市中医院针灸推拿...
伊朗称未来几天没有与美方谈判的... △巴加埃(资料图)当地时间29日晚间,伊朗外交部发言人巴加埃对外界表示,伊方未来几天没有与美方开展任...
关于霍尔木兹海峡排雷,伊朗:我... 伊朗外交部当地时间29日晚间在一份声明中表示,根据《伊斯兰堡谅解备忘录》,霍尔木兹海峡的排雷工作将由...
卡塔尔建议民众暂停出海 卡塔尔交通部29日建议民众暂停出海航行和海上活动。卡塔尔交通部当天在社交媒体发布公报说,为保障公共安...
朱克力:促进算力供给持续稳定普... 朱克力 | 立方大家谈专栏作者 当前,我国经济社会进入数字化智能化深度融合的发展阶段,生产方式、产业...
把脉“人工智能+” 求解教育科... 推进新质生产力发展,教育科技人才须同频共振;拥抱人工智能时代,技术创新当与人文精神相互校准。 近日...
“人造太阳”有新突破!可控核聚... 万亿级赛道传来好消息。 核聚变堆超导磁体研发取得重要突破 6月27日,我国“人造太阳”项目取得关键进...
原创 v... 影像在智能手机上,已成为核心之一,最高发展到专业级别,可拍摄场景更丰富。仅硬件方面,已推出2亿像素、...