Java后端面试题(线程池相关)(day11)

2024-08-29 09:44

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

目录

  • JDK内置线程池有哪几种?
    • FixedThreadPool
    • SingleThreadExecutor
    • CachedThreadPool
    • ScheduledThreadPool
  • 线程池常见参数有哪些?如何解释?
  • 为什么不推荐使用内置线程池?
  • 线程池的拒绝策略有哪些?

JDK内置线程池有哪几种?


FixedThreadPool

  • 创建一个固定大小的线程池。
  • 线程池中的线程数量是固定的,当一个任务完成后,这个线程会被用来执行另一个任务。
  • 如果提交的任务数量超过了线程的数量,那么超出的任务会被放在队列中等待。

SingleThreadExecutor

  • 创建一个单线程化的线程池。
  • 只有一个工作线程,确保所有任务按照指定顺序(FIFO,先进先出)执行。
  • 通常用于需要保证顺序执行的任务,例如更新GUI等。

CachedThreadPool

  • 创建一个可缓存的线程池。
  • 这种线程池能够自动调整线程数量,如果一段时间内没有新的任务提交,多余的空闲线程就会被终止。
  • 适合处理大量短时间的任务。

ScheduledThreadPool

  • 创建一个支持定时及周期性任务执行的线程池。
  • 支持在给定延迟后运行命令或者定期执行。
  • 可以用它来安排在将来某个时刻或定期执行的任务。

线程池常见参数有哪些?如何解释?


ThreadPoolExecutor 3 个最重要的参数:

  • corePoolSize : 核心线程数。这是线程池中始终维持的最小线程数。即使线程空闲,核心线程也不会被销毁。只有当线程池被关闭时,才会终止核心线程。
  • maximumPoolSize : 最大线程数。线程池允许创建的最大线程数。当任务队列满且等待的任务数量超过了队列容量时,线程池会创建新的线程来处理额外的任务,直到达到最大线程数。
  • workQueue任务队列。当提交的任务数量超过 corePoolSize 时,新提交的任务会被放置在这个队列中等待执行。

ThreadPoolExecutor其他常见参数 :

  • keepAliveTime:空闲线程的存活时间。
  • unit : keepAliveTime 参数的时间单位。
  • threadFactory :线程工厂。用于创建新线程,可以用来设置线程名称、优先级等。
  • handler :拒绝策略。

为什么不推荐使用内置线程池?


Executors 返回线程池对象的弊端如下:

  • FixedThreadPoolSingleThreadExecutor:使用的是有界阻塞队列是 LinkedBlockingQueue ,其任务队列的最大长度为 Integer.MAX_VALUE ,可能堆积大量的请求,从而导致 OOM(内存溢出)。
  • CachedThreadPool:使用的是同步队列 SynchronousQueue, 允许创建的线程数量为 Integer.MAX_VALUE ,如果任务数量过多且执行速度较慢,可能会创建大量的线程,从而导致 OOM(内存溢出)。
  • ScheduledThreadPoolSingleThreadScheduledExecutor :使用的无界的延迟阻塞队列 DelayedWorkQueue ,任务队列的最大长度为 Integer.MAX_VALUE ,可能堆积大量的请求,从而导致 OOM(内存溢出)。

线程池的拒绝策略有哪些?

如果当前同时运行的线程数量达到最大线程数量并且队列也已经被放满了任务时,ThreadPoolExecutor 定义一些策略:

  • AbortPolicy抛出 RejectedExecutionException异常来拒绝新任务的处理。
  • CallerRunsPolicy调用执行自己的线程运行任务,也就是直接在调用execute方法的线程中运行(run)被拒绝的任务,如果执行程序已关闭,则会丢弃该任务。
  • DiscardPolicy不处理新任务,直接丢弃掉。
  • DiscardOldestPolicy:此策略将丢弃最早的未处理的任务请求。

这篇关于Java后端面试题(线程池相关)(day11)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J

JAVA系统中Spring Boot应用程序的配置文件application.yml使用详解

《JAVA系统中SpringBoot应用程序的配置文件application.yml使用详解》:本文主要介绍JAVA系统中SpringBoot应用程序的配置文件application.yml的... 目录文件路径文件内容解释1. Server 配置2. Spring 配置3. Logging 配置4. Ma

Java 字符数组转字符串的常用方法

《Java字符数组转字符串的常用方法》文章总结了在Java中将字符数组转换为字符串的几种常用方法,包括使用String构造函数、String.valueOf()方法、StringBuilder以及A... 目录1. 使用String构造函数1.1 基本转换方法1.2 注意事项2. 使用String.valu

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

Spring MVC如何设置响应

《SpringMVC如何设置响应》本文介绍了如何在Spring框架中设置响应,并通过不同的注解返回静态页面、HTML片段和JSON数据,此外,还讲解了如何设置响应的状态码和Header... 目录1. 返回静态页面1.1 Spring 默认扫描路径1.2 @RestController2. 返回 html2

关于Maven生命周期相关命令演示

《关于Maven生命周期相关命令演示》Maven的生命周期分为Clean、Default和Site三个主要阶段,每个阶段包含多个关键步骤,如清理、编译、测试、打包等,通过执行相应的Maven命令,可以... 目录1. Maven 生命周期概述1.1 Clean Lifecycle1.2 Default Li

numpy求解线性代数相关问题

《numpy求解线性代数相关问题》本文主要介绍了numpy求解线性代数相关问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 在numpy中有numpy.array类型和numpy.mat类型,前者是数组类型,后者是矩阵类型。数组

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去