Java中并行执行任务的多种方式

2024-04-26 20:52

本文主要是介绍Java中并行执行任务的多种方式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在Java编程中,经常会遇到需要并行执行任务的情况,特别是在处理大量数据或者需要异步处理的场景下。本文将介绍几种常用的并行执行任务的方式,包括使用CompletableFuture、并行流、ExecutorServiceFuture,以及Fork/Join框架。

1. 使用CompletableFuture

CompletableFuture是Java 8引入的异步编程工具,提供了丰富的方法来处理异步任务。下面是一个简单的示例:

import java.util.concurrent.CompletableFuture;
import java.util.concurrent.ExecutionException;public class CompletableFutureExample {public static void main(String[] args) throws ExecutionException, InterruptedException {CompletableFuture<Integer> future1 = CompletableFuture.supplyAsync(() -> calculate(10));CompletableFuture<Integer> future2 = CompletableFuture.supplyAsync(() -> calculate(20));CompletableFuture<Void> combinedFuture = CompletableFuture.allOf(future1, future2);combinedFuture.get(); // 等待所有任务完成System.out.println("Result from future1: " + future1.get());System.out.println("Result from future2: " + future2.get());}public static int calculate(int number) {// 模拟耗时计算try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}return number * 2;}
}

2. 使用并行流

并行流是Java 8中引入的一种简化并行处理的方式,通过parallel()方法将普通流转换为并行流,可以利用多核处理器的优势进行并行处理。以下是一个示例:

import java.util.Arrays;public class ParallelStreamExample {public static void main(String[] args) {int[] numbers = {10, 20, 30, 40, 50};Arrays.stream(numbers).parallel() // 将流转换为并行流.mapToObj(number -> calculate(number)).forEach(result -> System.out.println("Result: " + result));}public static int calculate(int number) {// 模拟耗时计算try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}return number * 2;}
}

3. 使用ExecutorService和Future

ExecutorServiceFuture是Java中用于处理线程池和异步任务的工具。以下是一个使用ExecutorServiceFuture的示例:

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.*;public class ExecutorServiceExample {public static void main(String[] args) throws InterruptedException, ExecutionException {ExecutorService executor = Executors.newFixedThreadPool(2);List<Future<Integer>> futures = new ArrayList<>();for (int i = 0; i < 5; i++) {Future<Integer> future = executor.submit(new Task(i));futures.add(future);}executor.shutdown(); // 关闭线程池for (Future<Integer> future : futures) {System.out.println("Result: " + future.get());}}static class Task implements Callable<Integer> {private int number;public Task(int number) {this.number = number;}@Overridepublic Integer call() throws Exception {// 模拟耗时计算Thread.sleep(2000);return number * 2;}}
}

4. 使用Fork/Join框架

Fork/Join框架是Java中用于分治并行处理任务的工具。以下是一个简单的Fork/Join框架示例:

import java.util.concurrent.*;public class ForkJoinExample {public static void main(String[] args) {ForkJoinPool forkJoinPool = new ForkJoinPool();int[] array = {1, 2, 3, 4, 5};SumTask task = new SumTask(array, 0, array.length);int result = forkJoinPool.invoke(task);System.out.println("Sum: " + result);}static class SumTask extends RecursiveTask<Integer> {private int[] array;private int start;private int end;public SumTask(int[] array, int start, int end) {this.array = array;this.start = start;this.end = end;}@Overrideprotected Integer compute() {if (end - start <= 1) {return array[start];} else {int mid = start + (end - start) / 2;SumTask leftTask = new SumTask(array, start, mid);SumTask rightTask = new SumTask(array, mid, end);leftTask.fork();rightTask.fork();return leftTask.join() + rightTask.join();}}}
}

这些是Java中常用的几种并行执行任务的方式,你可以根据具体的场景和需求选择合适的方式。在选择时,需要考虑功能需求、性能要求、项目架构以及代码的可读性和维护性等因素。

这篇关于Java中并行执行任务的多种方式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/938633

相关文章

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

gradle第三方Jar包依赖统一管理方式

《gradle第三方Jar包依赖统一管理方式》:本文主要介绍gradle第三方Jar包依赖统一管理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景实现1.顶层模块build.gradle添加依赖管理插件2.顶层模块build.gradle添加所有管理依赖包

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.