【简说八股】为什么不建议通过Executors构建线程池?

2024-03-03 13:52

本文主要是介绍【简说八股】为什么不建议通过Executors构建线程池?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

Executors类看起来功能还是比较强大的,又用到了工厂模式、又有比较强的扩展性,重要的是用起来还比较方便,如:

ExecutorService executor = Executors.newFixedThreadPool(nThreads) ;

即可创建一个固定大小的线程池。

但是为什么在阿里巴巴Java开发手册中也明确指出,不允许使用Executors创建线程池呢
在这里插入图片描述

主要原因

阿里巴巴Java开发手册建议避免直接使用Executors类来创建线程池,主要出于以下几个考虑:

  1. 默认的队列大小和最大线程数可能导致资源耗尽

    • FixedThreadPool和SingleThreadExecutor使用无界队列LinkedBlockingQueue,默认最大容量为Integer.MAX_VALUE。在高负载情况下,可能导致内存溢出。
    • CachedThreadPool和ScheduledThreadPool允许创建的线程数量最大为Integer.MAX_VALUE,可能引发大量线程创建和内存溢出风险。
  2. 缺乏灵活性

    • Executors工厂方法创建的线程池参数预定义,不够灵活。直接使用ThreadPoolExecutor构造函数可以明确设置核心线程数、最大线程数、工作队列、拒绝策略等参数,更有利于根据业务需求进行优化。
  3. 隐藏了复杂性

    • Executors的便捷性隐藏了线程池内部的复杂性和细节,可能导致开发者对线程池运行机制理解不足,产生意外异常。
  4. 性能问题

    • 使用无界队列可能增加内存消耗,降低系统稳定性。任务过多可能导致线程上下文切换频繁,影响性能。

因此,建议直接使用ThreadPoolExecutor构造函数创建线程池,能更好地理解线程池工作原理,根据需求合理配置,避免潜在风险,提高系统稳定性和性能。虽然增加了编码复杂度,但获得更好的控制力和安全性是值得的。

四大线程池

线程池类型核心线程数固定最大线程数工作队列适用场景
FixedThreadPool固定LinkedBlockingQueue(无界队列)适用于执行长期的任务,控制线程最大数量
SingleThreadExecutor1LinkedBlockingQueue(无界队列)适用于需要顺序执行任务的场景
CachedThreadPool不是Integer.MAX_VALUESynchronousQueue(同步队列)适用于执行大量短期异步任务的场景
ScheduledThreadPool不是Integer.MAX_VALUEDelayedWorkQueue(延迟队列)适用于需要定时执行或周期性执行的任务

以上是对四种线程池类型的简要比较,以帮助选择最适合特定需求的线程池类型。

这篇关于【简说八股】为什么不建议通过Executors构建线程池?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

一文详解如何从零构建Spring Boot Starter并实现整合

《一文详解如何从零构建SpringBootStarter并实现整合》SpringBoot是一个开源的Java基础框架,用于创建独立、生产级的基于Spring框架的应用程序,:本文主要介绍如何从... 目录一、Spring Boot Starter的核心价值二、Starter项目创建全流程2.1 项目初始化(

Spring Boot3虚拟线程的使用步骤详解

《SpringBoot3虚拟线程的使用步骤详解》虚拟线程是Java19中引入的一个新特性,旨在通过简化线程管理来提升应用程序的并发性能,:本文主要介绍SpringBoot3虚拟线程的使用步骤,... 目录问题根源分析解决方案验证验证实验实验1:未启用keep-alive实验2:启用keep-alive扩展建

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

使用Python和python-pptx构建Markdown到PowerPoint转换器

《使用Python和python-pptx构建Markdown到PowerPoint转换器》在这篇博客中,我们将深入分析一个使用Python开发的应用程序,该程序可以将Markdown文件转换为Pow... 目录引言应用概述代码结构与分析1. 类定义与初始化2. 事件处理3. Markdown 处理4. 转

Java终止正在运行的线程的三种方法

《Java终止正在运行的线程的三种方法》停止一个线程意味着在任务处理完任务之前停掉正在做的操作,也就是放弃当前的操作,停止一个线程可以用Thread.stop()方法,但最好不要用它,本文给大家介绍了... 目录前言1. 停止不了的线程2. 判断线程是否停止状态3. 能停止的线程–异常法4. 在沉睡中停止5

Java使用Mail构建邮件功能的完整指南

《Java使用Mail构建邮件功能的完整指南》JavaMailAPI是一个功能强大的工具,它可以帮助开发者轻松实现邮件的发送与接收功能,本文将介绍如何使用JavaMail发送和接收邮件,希望对大家有所... 目录1、简述2、主要特点3、发送样例3.1 发送纯文本邮件3.2 发送 html 邮件3.3 发送带

Java捕获ThreadPoolExecutor内部线程异常的四种方法

《Java捕获ThreadPoolExecutor内部线程异常的四种方法》这篇文章主要为大家详细介绍了Java捕获ThreadPoolExecutor内部线程异常的四种方法,文中的示例代码讲解详细,感... 目录方案 1方案 2方案 3方案 4结论方案 1使用 execute + try-catch 记录

Python结合Flask框架构建一个简易的远程控制系统

《Python结合Flask框架构建一个简易的远程控制系统》这篇文章主要为大家详细介绍了如何使用Python与Flask框架构建一个简易的远程控制系统,能够远程执行操作命令(如关机、重启、锁屏等),还... 目录1.概述2.功能使用系统命令执行实时屏幕监控3. BUG修复过程1. Authorization

Spring Boot 中正确地在异步线程中使用 HttpServletRequest的方法

《SpringBoot中正确地在异步线程中使用HttpServletRequest的方法》文章讨论了在SpringBoot中如何在异步线程中正确使用HttpServletRequest的问题,... 目录前言一、问题的来源:为什么异步线程中无法访问 HttpServletRequest?1. 请求上下文与线

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分