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

相关文章

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

Python+FFmpeg实现视频自动化处理的完整指南

《Python+FFmpeg实现视频自动化处理的完整指南》本文总结了一套在Python中使用subprocess.run调用FFmpeg进行视频自动化处理的解决方案,涵盖了跨平台硬件加速、中间素材处理... 目录一、 跨平台硬件加速:统一接口设计1. 核心映射逻辑2. python 实现代码二、 中间素材处

Java方法重载与重写之同名方法的双面魔法(最新整理)

《Java方法重载与重写之同名方法的双面魔法(最新整理)》文章介绍了Java中的方法重载Overloading和方法重写Overriding的区别联系,方法重载是指在同一个类中,允许存在多个方法名相同... 目录Java方法重载与重写:同名方法的双面魔法方法重载(Overloading):同门师兄弟的不同绝

idea设置快捷键风格方式

《idea设置快捷键风格方式》在IntelliJIDEA中设置快捷键风格,打开IDEA,进入设置页面,选择Keymap,从Keymaps下拉列表中选择或复制想要的快捷键风格,点击Apply和OK即可使... 目录idea设www.chinasem.cn置快捷键风格按照以下步骤进行总结idea设置快捷键pyth

Linux镜像文件制作方式

《Linux镜像文件制作方式》本文介绍了Linux镜像文件制作的过程,包括确定磁盘空间布局、制作空白镜像文件、分区与格式化、复制引导分区和其他分区... 目录1.确定磁盘空间布局2.制作空白镜像文件3.分区与格式化1) 分区2) 格式化4.复制引导分区5.复制其它分区1) 挂载2) 复制bootfs分区3)

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配

Java中ArrayList与顺序表示例详解

《Java中ArrayList与顺序表示例详解》顺序表是在计算机内存中以数组的形式保存的线性表,是指用一组地址连续的存储单元依次存储数据元素的线性结构,:本文主要介绍Java中ArrayList与... 目录前言一、Java集合框架核心接口与分类ArrayList二、顺序表数据结构中的顺序表三、常用代码手动

JAVA项目swing转javafx语法规则以及示例代码

《JAVA项目swing转javafx语法规则以及示例代码》:本文主要介绍JAVA项目swing转javafx语法规则以及示例代码的相关资料,文中详细讲解了主类继承、窗口创建、布局管理、控件替换、... 目录最常用的“一行换一行”速查表(直接全局替换)实际转换示例(JFramejs → JavaFX)迁移建

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过