java-java8并行接口的选用策略

并行——使用流还是CompletableFutures?
目前为止,你已经知道对集合进行并行计算有两种方式:
1 要么将其转化为并行流,利用map这样的操作开展工作。
2 要么枚举出集合中的每一个元素,创建新的线程,在CompletableFuture内对其进行操作。

后者提供了更多的灵活性,你可以调整线程池的大小,而这能帮助 你确保整体的计算不会因为线程都在等待I/O而发生阻塞。

我们对使用这些API的建议如下。

❑如果你进行的是计算密集型的操作,并且没有I/O,那么推荐使用Stream接口,因为实
现简单,同时效率也可能是最高的(如果所有的线程都是计算密集型的,那就没有必要
创建比处理器核数更多的线程)。
❑反之,如果你并行的工作单元还涉及等待I/O的操作(包括网络连接等待),那么使用
CompletableFuture灵活性更好,你可以像前文讨论的那样,依据等待/计算,或者 W/C的比率设定需要使用的线程数。这种情况不使用并行流的另一个原因是,处理流的 流水线中如果发生I/O等待,流的延迟特性会让我们很难判断到底什么时候触发了等待。

image.png

没错,这些干货来自- java8实战这本书,推荐阅读!!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本文是我自己在秋招复习时的读书笔记,整理的知识点,也是为了防止忘记,尊重劳动成果,转载注明出处哦!如果你也喜欢,那...
    波波波先森阅读 11,334评论 4 56
  • 本文主要总结了《Java8实战》,适用于学习 Java8 的同学,也可以作为一个 API 手册文档适用,平时使用时...
    _晓__阅读 1,196评论 1 6
  • 1.ios高性能编程 (1).内层 最小的内层平均值和峰值(2).耗电量 高效的算法和数据结构(3).初始化时...
    欧辰_OSR阅读 29,645评论 8 265
  • 我到底是个什么样的人呢 我有时候很大方 有时候又很自私 我羡慕交际能力好的人 又嫌弃像傻子一样的人 有时候我嫉...
    就叫阿洲吧阅读 263评论 0 0
  • 天阔地大,万物入冬, 袅袅炊烟,人间万暖, 天渐暮色,万家灯火, 归人匆匆,觅那一灯。 屋中女人,且待归人, 灶前...
    若幽兰阅读 223评论 0 0