ParallelStreamPerformance

package com.shrimpking.t4;

/**
 * Created by IntelliJ IDEA.
 *
 * @Author : Shrimpking
 * @create 2024/9/12 12:09
 */
public interface Test
{
    void test();
}
package com.shrimpking.t4;

/**
 * Created by IntelliJ IDEA.
 *
 * @Author : Shrimpking
 * @create 2024/9/12 12:10
 */
public class Tester
{
    public static long runTest(Test t){
        long start = System.currentTimeMillis();
        t.test();
        long end = System.currentTimeMillis();
        return end - start;
    }
}
package com.shrimpking.t4;

import java.util.stream.LongStream;

/**
 * Created by IntelliJ IDEA.
 *
 * @Author : Shrimpking
 * @create 2024/9/12 12:09
 */
public class ParallelStreamPerformance
{
    public static void main(String[] args)
    {
        LongStream stream1 = LongStream.rangeClosed(1L,1000L);
//        long time1 = Tester.runTest(new Test()
//        {
//            @Override
//            public void test()
//            {
//                stream1.reduce(0L,Long::sum);
//            }
//        });
        long time1 = Tester.runTest(() -> stream1.reduce(0L,Long::sum));
        System.out.println("串行流花费时间:" + time1);

        LongStream stream2 = LongStream.rangeClosed(1L,1000L).parallel();
        long time2 = Tester.runTest(()-> stream2.reduce(0L,Long::sum));
        System.out.println("并行流花费时间:" + time2);

        LongStream stream3 = LongStream.rangeClosed(1L,100000000L);
        long time3 = Tester.runTest(() -> stream3.reduce(0L,Long::sum));
        System.out.println("数据量大串行流花费时间:" + time3);

        LongStream stream4 = LongStream.rangeClosed(1L,100000000L).parallel();
        long time4 = Tester.runTest(() -> stream4.reduce(0L,Long::sum));
        System.out.println("数据量大并行流花费时间:" + time4);

        //并行流的性能
        //处理少量数据时,并行流与串行流差距不大
        //处理大量数据时,并行流优势明显


    }
}

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

虾米大王

有你的支持,我会更有动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值