parallel循环java_Java 8 lambda stream forEach parallel 等循环与Java 7 for each 循环耗时测试…[通俗易懂]

parallel循环java_Java 8 lambda stream forEach parallel 等循环与Java 7 for each 循环耗时测试…[通俗易懂]Java8里面的stream有串行流和并行流之分。说高级的stream就是那个并行流。下面是那个并行流的简单实现。只要是继承Collection类的都可以这么用。list.stream().parallel()list.parallelStream()先看代码和运行结果,再解释一下,这个并行串行流之间的差别。packagecom.lxk.lambdaTest;importcom.goog…

大家好,又见面了,我是你们的朋友全栈君。

Java 8 里面的stream 有串行流和并行流之分。

说高级的stream就是那个并行流。下面是那个并行流的简单实现。只要是继承Collection类的都可以这么用。

list.stream().parallel()

list.parallelStream()

先看代码和运行结果,再解释一下,这个并行串行流之间的差别。

package com.lxk.lambdaTest;

import com.google.common.collect.Lists;

import java.util.List;

/**

* 测试性能(Java 8 的循环和Java 7 的循环耗时的对比测试)

*

* Created by lxk on 2017/8/31

*/

public class Performance {

public static void main(String[] args) {

List list = getLoopList();

normalBeforeLoop(list);

normalAfterLoop(list);

notNormalAfterLoop(list);

}

private static void notNormalAfterLoop(List list) {

long a = System.currentTimeMillis();

list.stream().parallel().forEach(System.out::print);

System.out.println(” list.stream().parallel().forEach 执行耗时 : ” + (System.currentTimeMillis() – a) / 1000f + ” 秒 “);

}

private static void normalAfterLoop(List list) {

long a = System.currentTimeMillis();

list.stream().forEach(System.out::print);

System.out.println(” list.stream().forEach 执行耗时 : ” + (System.currentTimeMillis() – a) / 1000f + ” 秒 “);

a = System.currentTimeMillis();

list.forEach(System.out::print);

System.out.println(” list.forEach 执行耗时 : ” + (System.currentTimeMillis() – a) / 1000f + ” 秒 “);

}

private static void normalBeforeLoop(List list) {

long a = System.currentTimeMillis();

for (String s : list) {

System.out.print(s);

}

System.out.println(” for each 执行耗时 : ” + (System.currentTimeMillis() – a) / 1000f + ” 秒 “);

}

private static List getLoopList() {

List list = Lists.newArrayList();

for (int i = 0; i < 10000; i++) {

list.add(“item ” + i);

}

return list;

}

}

下面是代码运行结果:

0818b9ca8b590ca3270a3433284dd417.png

好,关于,那个并行和串行的流的差别,可以看到啦。

并行的流,在循环的时候,就不是 1 – 9999 挨着输出。而是,看多核的心情。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/161827.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月19日 上午6:16
下一篇 2022年7月19日 上午6:36


相关推荐

  • Hdu1396「建议收藏」

    Hdu1396「建议收藏」//CountingTriangles/*顶角朝上的三角形:a[i]=a[i-1]+c(i+1,2)(从底边任选两点为正三角形底边)顶角朝下的三角形:b[i]=b[i-1]+c((i+1)/2,2)+c((i+2)/2,2)(因为偶数边长的正三角形和其边长一半的反三角形存在着对应关系,所以将底边所有的点分为两类:奇数和偶数点;再在相应的奇数…

    2022年8月12日
    9
  • LoRaWAN架构简介

    LoRaWAN架构简介LoRaWAN 整体概览 LoRaWAN 协议层次 LoRaWAN 是定义在 LoRa 无线调制技术上的一整套通信协议 类似 TCP IP 协议 LoRaWAN 整个协议的架构图分为几层 绿色的 Application 层是给用户提供数据使用的 主要由用户自己根据需求来进行开发就好 蓝色的 MAC 层是 LoRa 的链接层协议 更详细的内容在 LoRaWAN 标准中可以查看 棕色的 LoRaModulati 对应 OSI 的物理层协议 在具体的应用中 其实就是指 sx127x 或 sx12

    2026年3月26日
    1
  • js中数组常用遍历,VUE 中数组常用遍历

    js中数组常用遍历,VUE 中数组常用遍历VUE 中常用 for 循环

    2026年3月26日
    3
  • Docker 环境下 OpenClaw Gateway 无法访问的故障排查指南

    Docker 环境下 OpenClaw Gateway 无法访问的故障排查指南

    2026年3月13日
    3
  • 银行ATM活动图文档

    银行ATM活动图文档银行ATM问题陈述、词汇表、领域类图链接:http://blog.csdn.net/yingyingbaibai/article/details/70216506银行ATM用况图文档链接:http://blog.csdn.net/yingyingbaibai/article/details/70216792银行ATM分析类类图文档链接:http://blog.csdn.

    2022年5月24日
    31
  • ajax跨域的解决办法_前端跨域解决方案

    ajax跨域的解决办法_前端跨域解决方案什么是AJAX?AJAX是无需刷新页面就能够从服务器去的数据的一种方法,负责Ajax运作的核心对象是XMLHttpRequest(XHR)对象。同源策略是对XHR的一个主要约束,它为通信设置了“相同的域、相同的端口、相同的协议”这一限制。试图访问上述限制之外的资源都会引发安全错误,除非采用被认可的跨域解决方案。这个方案叫做CORS(Cross-OriginResource

    2022年8月24日
    11

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号