加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

斯卡拉 – 阿卡未来 – 并行与并发?

发布时间:2020-12-16 18:43:08 所属栏目:安全 来源:网络整理
导读:从写得好的 Akka Concurrency: 据我所知,该图指出,numSummer和charConcat都将在同一个线程上运行. 是否可以并行运行每个Future,即在不同的线程上运行? 解决方法 左边的图片是他们并行运行的. 插图的要点是Future.apply方法启动了执行,所以如果直到第一个未
从写得好的 Akka Concurrency:

enter image description here

据我所知,该图指出,numSummer和charConcat都将在同一个线程上运行.

是否可以并行运行每个Future,即在不同的线程上运行?

解决方法

左边的图片是他们并行运行的.

插图的要点是Future.apply方法启动了执行,所以如果直到第一个未来的结果是flatMaped(如右图所示),那么你就没有得到并行执行.

(请注意,通过“kicked off”,我的意思是相关的ExecutionContext被告知作业.它如何并行化是一个不同的问题,可能取决于其线程池的大小等.)

左边的等价代码:

val numSummer = Future { ... }  // execution kicked off
val charConcat = Future { ... }  // execution kicked off
numSummer.flatMap { numsum =>
  charConcat.map { string =>
    (numsum,string)
  }
}

并为正确的:

Future { ... }  // execution kicked off
  .flatMap { numsum =>
    Future { ... }  // execution kicked off (Note that this does not happen until
                    // the first future's result (`numsum`) is available.)
      .map { string =>
        (numsum,string)
      }
  }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读