斯卡拉 – 阿卡未来 – 并行与并发?
发布时间:2020-12-16 18:43:08 所属栏目:安全 来源:网络整理
导读:从写得好的 Akka Concurrency: 据我所知,该图指出,numSummer和charConcat都将在同一个线程上运行. 是否可以并行运行每个Future,即在不同的线程上运行? 解决方法 左边的图片是他们并行运行的. 插图的要点是Future.apply方法启动了执行,所以如果直到第一个未
从写得好的
Akka Concurrency:
据我所知,该图指出,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) } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |