11.ForkJoin
ForkJoin
ForkJoin在jdk1.7,并行执行任务!提高效率,大数据量!
大数据:Map Reduce(把大任务拆分成小任务)
ForkJoin特点:工作窃取(如下图)
ForkJoin操作
如何使用。累加求和
-
forkJoinPool来执行
-
计算任务forkJoinPool.execute(ForkJoinTask<?> task)
-
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);
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· 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