Java中线程池相关的七个参数

2023-12-04 20:12

本文主要是介绍Java中线程池相关的七个参数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在Java中,线程池的七个参数是指线程池的相关配置参数,用来控制线程池的行为和性能。这些参数包括:

1. 核心线程数(corePoolSize):线程池中保持的最小线程数,即使线程处于空闲状态,也不会被回收。

2. 最大线程数(maximumPoolSize):线程池中允许存在的最大线程数,当任务数量超过核心线程数时,线程池会创建新的线程,直到达到最大线程数。

3. 空闲线程存活时间(keepAliveTime):当线程池中的线程数量超过核心线程数,并且处于空闲状态时,这些多余的线程在超过指定时间后会被回收销毁。

4. 时间单位(unit):空闲线程存活时间的单位,可以是秒、毫秒、分钟等。

5. 任务队列(workQueue):用于存放待执行任务的阻塞队列。当线程池中的线程都在工作且任务队列已满时,新的任务会被拒绝执行。

6. 线程工厂(threadFactory):用于创建新线程的工厂,可以自定义线程的名称、优先级等属性。

7. 饱和策略(handler):当任务无法执行时的处理策略,有以下几种选择:
   - ThreadPoolExecutor.AbortPolicy:默认策略,抛出RejectedExecutionException异常。
   - ThreadPoolExecutor.CallerRunsPolicy:由调用线程执行该任务。
   - ThreadPoolExecutor.DiscardPolicy:直接丢弃无法执行的任务。
   - ThreadPoolExecutor.DiscardOldestPolicy:丢弃最早提交的任务,然后尝试执行新任务。

通过合理调优这些参数,可以根据具体的业务需求来提升线程池的性能和效率。需要根据实际情况进行选择和配置,以平衡系统资源和任务处理能力。

线程池原理图示:

图片来源:https://www.cnblogs.com/yangj-Blog/p/13118694.html

下面是创建自定义线程池的代码示例:

import java.util.concurrent.*;public class CustomerThreadPool {//    static  class SimpleThreadFactory implements ThreadFactory {
//        public Thread newThread(Runnable r) {
//            return new Thread(r);
//        }
//    }static class MyAbortPolicy implements RejectedExecutionHandler {/*** Creates an {@code AbortPolicy}.*/public MyAbortPolicy() {}/*** Always throws RejectedExecutionException.** @param r the runnable task requested to be executed* @param e the executor attempting to execute this task* @throws RejectedExecutionException always*/public void rejectedExecution(Runnable r, ThreadPoolExecutor e) {throw new RejectedExecutionException("任务 " + r.toString() +" 拒绝 from " +e.toString());}}public static void main(String[] args) {int corePoolSize = 4;int maximumPoolSize = 10;long keepAliveTime = 10000;TimeUnit unit = TimeUnit.MILLISECONDS;BlockingQueue<Runnable> workQueue = new LinkedBlockingQueue<>(10);
//        ThreadFactory threadFactory = new ThreadFactory() {
//            @Override
//            public Thread newThread(Runnable r) {
//                System.out.println("创建线程:"+r);
//                return new Thread(r);
//            }
//        };RejectedExecutionHandler handler = null;ThreadPoolExecutor myPool = new ThreadPoolExecutor(corePoolSize,maximumPoolSize,keepAliveTime,unit,workQueue,r -> {System.out.println("创建线程:" + r);return new Thread(r);},new MyAbortPolicy());for (int t = 0; t < 30; t++) {myPool.execute(() -> {for (int i = 0; i < 10; i++) {System.out.println(Thread.currentThread().getName() + ":" + i);try {Thread.sleep(200);} catch (InterruptedException e) {e.printStackTrace();}}});}}
}

在这个示例中,我们创建了一个自定义的线程池。通过设置参数来自定义线程池的行为,包括核心线程数、最大线程数、空闲线程存活时间、任务队列容量等。同时,还提供了自定义的线程工厂和饱和策略。

通过自定义这些参数和组件,可以灵活地控制线程池的行为,以适应不同的需求和场景。

需要注意的是:

图片来源:《阿里java开发手册2019 1.5》

参考

java线程池 - To_Yang - 博客园


这篇关于Java中线程池相关的七个参数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Apache Ignite 与 Spring Boot 集成详细指南

《ApacheIgnite与SpringBoot集成详细指南》ApacheIgnite官方指南详解如何通过SpringBootStarter扩展实现自动配置,支持厚/轻客户端模式,简化Ign... 目录 一、背景:为什么需要这个集成? 二、两种集成方式(对应两种客户端模型) 三、方式一:自动配置 Thick

Spring WebClient从入门到精通

《SpringWebClient从入门到精通》本文详解SpringWebClient非阻塞响应式特性及优势,涵盖核心API、实战应用与性能优化,对比RestTemplate,为微服务通信提供高效解决... 目录一、WebClient 概述1.1 为什么选择 WebClient?1.2 WebClient 与

Java.lang.InterruptedException被中止异常的原因及解决方案

《Java.lang.InterruptedException被中止异常的原因及解决方案》Java.lang.InterruptedException是线程被中断时抛出的异常,用于协作停止执行,常见于... 目录报错问题报错原因解决方法Java.lang.InterruptedException 是 Jav

深入浅出SpringBoot WebSocket构建实时应用全面指南

《深入浅出SpringBootWebSocket构建实时应用全面指南》WebSocket是一种在单个TCP连接上进行全双工通信的协议,这篇文章主要为大家详细介绍了SpringBoot如何集成WebS... 目录前言为什么需要 WebSocketWebSocket 是什么Spring Boot 如何简化 We

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

Java Stream流之GroupBy的用法及应用场景

《JavaStream流之GroupBy的用法及应用场景》本教程将详细介绍如何在Java中使用Stream流的groupby方法,包括基本用法和一些常见的实际应用场景,感兴趣的朋友一起看看吧... 目录Java Stream流之GroupBy的用法1. 前言2. 基础概念什么是 GroupBy?Stream

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、