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

相关文章

Python中edge-tts实现便捷语音合成

《Python中edge-tts实现便捷语音合成》edge-tts是一个功能强大的Python库,支持多种语言和声音选项,本文主要介绍了Python中edge-tts实现便捷语音合成,具有一定的参考价... 目录安装与环境设置文本转语音查找音色更改语音参数生成音频与字幕总结edge-tts 是一个功能强大的

Java实现按字节长度截取字符串

《Java实现按字节长度截取字符串》在Java中,由于字符串可能包含多字节字符,直接按字节长度截取可能会导致乱码或截取不准确的问题,下面我们就来看看几种按字节长度截取字符串的方法吧... 目录方法一:使用String的getBytes方法方法二:指定字符编码处理方法三:更精确的字符编码处理使用示例注意事项方

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

Python+PyQt5开发一个Windows电脑启动项管理神器

《Python+PyQt5开发一个Windows电脑启动项管理神器》:本文主要介绍如何使用PyQt5开发一款颜值与功能并存的Windows启动项管理工具,不仅能查看/删除现有启动项,还能智能添加新... 目录开篇:为什么我们需要启动项管理工具功能全景图核心技术解析1. Windows注册表操作2. 启动文件

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

Android 实现一个隐私弹窗功能

《Android实现一个隐私弹窗功能》:本文主要介绍Android实现一个隐私弹窗功能,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 效果图如下:1. 设置同意、退出、点击用户协议、点击隐私协议的函数参数2. 《用户协议》、《隐私政策》设置成可点击的,且颜色要区分出来res/l

Spring三级缓存解决循环依赖的解析过程

《Spring三级缓存解决循环依赖的解析过程》:本文主要介绍Spring三级缓存解决循环依赖的解析过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、循环依赖场景二、三级缓存定义三、解决流程(以ServiceA和ServiceB为例)四、关键机制详解五、设计约

spring IOC的理解之原理和实现过程

《springIOC的理解之原理和实现过程》:本文主要介绍springIOC的理解之原理和实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、IoC 核心概念二、核心原理1. 容器架构2. 核心组件3. 工作流程三、关键实现机制1. Bean生命周期2.

Redis实现分布式锁全解析之从原理到实践过程

《Redis实现分布式锁全解析之从原理到实践过程》:本文主要介绍Redis实现分布式锁全解析之从原理到实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、背景介绍二、解决方案(一)使用 SETNX 命令(二)设置锁的过期时间(三)解决锁的误删问题(四)Re

解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException: org.junit.Test问题

《解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException:org.junit.Test问题》:本文主要介绍解决tomcat启动时报Junit相... 目录tomcat启动时报Junit相关错误Java.lang.ClassNotFoundException