11.ForkJoin

ForkJoin

ForkJoin在jdk1.7,并行执行任务!提高效率,大数据量!

大数据:Map Reduce(把大任务拆分成小任务)

ForkJoin特点:工作窃取(如下图)

ForkJoin操作

如何使用。累加求和

  1. forkJoinPool来执行

  2. 计算任务forkJoinPool.execute(ForkJoinTask<?> task)

  3. ForkJoinTask.计算任务要集成此类

1.四大函数式接口,Function,Predicate,Consumer,Supplier

2.forkJoinPool拆分式计算,demo测试

public class Test {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        //test1();//普通for循环 328
        //test2();//forkjoin 4813
        test3();//并行流,247
    }

    //普通
    public static void test1() {
        long start = System.currentTimeMillis();
        long sum = 0L;
        for (long i = 1L; i <= 10_0000_0000L; i++) {
            sum += i;
        }
        long end = System.currentTimeMillis();
        System.out.println("时间:" + (end - start) + ",sum=" + sum);
    }

    //forkjoin
    public static void test2() throws ExecutionException, InterruptedException {
        long start = System.currentTimeMillis();
        ForkJoinPool forkJoinPool = new ForkJoinPool();
        ForkJoinTask<Long> submit = forkJoinPool.submit(new ForkJoinDemo(1L, 10_0000_0000L));
        Long sum = submit.get();
        long end = System.currentTimeMillis();
        System.out.println("时间:" + (end - start) + ",sum=" + sum);
    }

    //并行流
    public static void test3() {
        long start = System.currentTimeMillis();
        long sum = 0L;
        sum = LongStream.rangeClosed(0L, 10_0000_0000L).parallel().reduce(0, Long::sum);
        long end = System.currentTimeMillis();
        System.out.println("时间:" + (end - start) + ",sum=" + sum);
    }
}
posted @   jpy  阅读(2)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示