Java中实现和管理线程池有哪些方式?

2024-09-01 11:28

本文主要是介绍Java中实现和管理线程池有哪些方式?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 Java 中,实现和管理线程池有多种方式。以下是几种常见的方式,包括使用 Executors 工具类、直接使用 ThreadPoolExecutor、自定义线程池等。

1. 使用 Executors 工具类

Executors 工具类提供了几种便捷的方法来创建常见类型的线程池:

1.1 固定大小线程池 (Fixed Thread Pool)

适用于需要固定数量线程处理任务的场景。

ExecutorService fixedThreadPool = Executors.newFixedThreadPool(4);// 提交任务到线程池
fixedThreadPool.submit(() -> {// 任务逻辑
});// 关闭线程池
fixedThreadPool.shutdown();
1.2 缓存线程池 (Cached Thread Pool)

适用于大量短生命周期任务的场景,线程池大小根据需要自动调整。

ExecutorService cachedThreadPool = Executors.newCachedThreadPool();// 提交任务到线程池
cachedThreadPool.submit(() -> {// 任务逻辑
});// 关闭线程池
cachedThreadPool.shutdown();
1.3 单线程池 (Single Thread Executor)

确保任务按顺序执行,只有一个线程。

ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();// 提交任务到线程池
singleThreadExecutor.submit(() -> {// 任务逻辑
});// 关闭线程池
singleThreadExecutor.shutdown();
1.4 调度线程池 (Scheduled Thread Pool)

用于周期性或定时执行任务。

ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(2);// 提交延时任务
scheduledThreadPool.schedule(() -> {// 任务逻辑
}, 5, TimeUnit.SECONDS);// 提交周期性任务
scheduledThreadPool.scheduleAtFixedRate(() -> {// 任务逻辑
}, 0, 10, TimeUnit.SECONDS);// 关闭线程池
scheduledThreadPool.shutdown();

2. 直接使用 ThreadPoolExecutor

ThreadPoolExecutor 提供了更高级的线程池配置选项,适用于需要高度定制的场景。

2.1 使用 ThreadPoolExecutor 创建线程池
int corePoolSize = 2;
int maximumPoolSize = 4;
long keepAliveTime = 10;
TimeUnit unit = TimeUnit.SECONDS;
BlockingQueue<Runnable> workQueue = new ArrayBlockingQueue<>(2);RejectedExecutionHandler handler = new ThreadPoolExecutor.CallerRunsPolicy();ExecutorService threadPool = new ThreadPoolExecutor(corePoolSize,maximumPoolSize,keepAliveTime,unit,workQueue,Executors.defaultThreadFactory(),handler);// 提交任务到线程池
threadPool.submit(() -> {// 任务逻辑
});// 关闭线程池
threadPool.shutdown();

3. 自定义线程池

您可以通过实现 ThreadFactory 接口或自定义 RejectedExecutionHandler 来创建更复杂的线程池行为。

3.1 自定义 ThreadFactory

用于定制新创建线程的属性,比如名称、优先级等。

ThreadFactory customThreadFactory = new ThreadFactory() {private final AtomicInteger threadNumber = new AtomicInteger(1);@Overridepublic Thread newThread(Runnable r) {Thread thread = new Thread(r);thread.setName("CustomThread-" + threadNumber.getAndIncrement());thread.setPriority(Thread.NORM_PRIORITY);return thread;}
};ExecutorService customThreadPool = new ThreadPoolExecutor(2, 4, 60L, TimeUnit.SECONDS, new SynchronousQueue<>(), customThreadFactory);customThreadPool.submit(() -> {// 任务逻辑
});customThreadPool.shutdown();
3.2 自定义 RejectedExecutionHandler

用于定制任务被拒绝时的处理逻辑。

RejectedExecutionHandler customHandler = new RejectedExecutionHandler() {@Overridepublic void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {System.out.println("Task rejected: " + r.toString());// 自定义处理逻辑}
};ExecutorService customThreadPoolWithHandler = new ThreadPoolExecutor(2, 4, 60L, TimeUnit.SECONDS, new ArrayBlockingQueue<>(2), customHandler);customThreadPoolWithHandler.submit(() -> {// 任务逻辑
});customThreadPoolWithHandler.shutdown();

4. ForkJoinPool

ForkJoinPool 是专为任务分解和合并设计的高级线程池,适用于并行计算任务。

ForkJoinPool forkJoinPool = new ForkJoinPool();ForkJoinTask<?> task = forkJoinPool.submit(() -> {// 分解和合并任务
});task.join(); // 等待任务完成forkJoinPool.shutdown();

5. CompletableFuture

CompletableFuture 提供了异步任务的更高层次抽象,并支持链式处理和组合。

CompletableFuture.supplyAsync(() -> {// 异步任务return "Result";
}).thenApply(result -> {// 下一步处理return result.toUpperCase();
}).thenAccept(System.out::println);

小结

  • Executors 工具类:提供便捷的固定大小线程池、缓存线程池、单线程池和调度线程池的创建方法,适用于大多数常见应用场景。
  • ThreadPoolExecutor:提供高度灵活的线程池配置选项,适用于需要精细控制线程池行为的场景。
  • 自定义线程池:通过实现 ThreadFactoryRejectedExecutionHandler 接口,可以创建具有特定行为和属性的线程池。
  • ForkJoinPool:适用于需要将任务分解为更小子任务并行执行的场景。
  • CompletableFuture:提供流式 API 和组合功能用于异步任务处理,非常适合复杂的异步编程。

选择适合的线程池实现和管理方式可以有效提升多线程应用的性能和可维护性。

这篇关于Java中实现和管理线程池有哪些方式?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

SpringBoot条件注解核心作用与使用场景详解

《SpringBoot条件注解核心作用与使用场景详解》SpringBoot的条件注解为开发者提供了强大的动态配置能力,理解其原理和适用场景是构建灵活、可扩展应用的关键,本文将系统梳理所有常用的条件注... 目录引言一、条件注解的核心机制二、SpringBoot内置条件注解详解1、@ConditionalOn

OpenCV图像形态学的实现

《OpenCV图像形态学的实现》本文主要介绍了OpenCV图像形态学的实现,包括腐蚀、膨胀、开运算、闭运算、梯度运算、顶帽运算和黑帽运算,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起... 目录一、图像形态学简介二、腐蚀(Erosion)1. 原理2. OpenCV 实现三、膨胀China编程(

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Android实现打开本地pdf文件的两种方式

《Android实现打开本地pdf文件的两种方式》在现代应用中,PDF格式因其跨平台、稳定性好、展示内容一致等特点,在Android平台上,如何高效地打开本地PDF文件,不仅关系到用户体验,也直接影响... 目录一、项目概述二、相关知识2.1 PDF文件基本概述2.2 android 文件访问与存储权限2.

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Spring LDAP目录服务的使用示例

《SpringLDAP目录服务的使用示例》本文主要介绍了SpringLDAP目录服务的使用示例... 目录引言一、Spring LDAP基础二、LdapTemplate详解三、LDAP对象映射四、基本LDAP操作4.1 查询操作4.2 添加操作4.3 修改操作4.4 删除操作五、认证与授权六、高级特性与最佳

Spring Shell 命令行实现交互式Shell应用开发

《SpringShell命令行实现交互式Shell应用开发》本文主要介绍了SpringShell命令行实现交互式Shell应用开发,能够帮助开发者快速构建功能丰富的命令行应用程序,具有一定的参考价... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定义S

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle