面试官:说一下线程池的参数,核心线程非核心线程使用方法,拒绝策略

简介: 面试官:说一下线程池的参数,核心线程非核心线程使用方法,拒绝策略

线程池的参数:

1. corePoolSize:核心线程数

2. maximumPoolSize:最大线程数

3.workQueue:阻塞队列

4.ThreadFactory:线程工厂

5.keepAliveTime:非核心线程存活时间

6.TimeUnit:时间单元

7.RejectedExecutionHandler:拒绝策略

 

核心线程非核心线程使用方法

当有一个任务需要线程的时候,如果线程池中有空闲线程就去执行任务,如果没有空闲的线程,检查已经创建的线程数是不是小于指定的核心线程数,如果小于就创建一个线程去执行指定的任务,如果大于检查阻塞队列是不是满了,如果没有满任务放入队列,如果满了,检查所有的线程数是否小于之前指定的最大的线程数,如果小于就创建一个线程去执行当前任务,如果已经创建的线程数大于等于最大线程数并且阻塞队列也满了,就去执行拒绝策略处理当前任务。

 

拒绝策略

一共包含四种拒绝策略。

1. 抛弃任务并且不抛出异常

2. 抛弃任务然后抛出异常

3. 删除阻塞队列中等待时间最长并把当前任务加入队列

4. 交给调用者去处理,就是谁把这个任务发送给线程池处理谁去处理那个任务。

相关文章
|
2月前
|
Prometheus 监控 Cloud Native
JAVA线程池监控以及动态调整线程池
【10月更文挑战第22天】在 Java 中,线程池的监控和动态调整是非常重要的,它可以帮助我们更好地管理系统资源,提高应用的性能和稳定性。
190 64
|
8天前
|
缓存 安全 Java
【JavaEE】——单例模式引起的多线程安全问题:“饿汉/懒汉”模式,及解决思路和方法(面试高频)
单例模式下,“饿汉模式”,“懒汉模式”,单例模式下引起的线程安全问题,解锁思路和解决方法
|
8天前
|
Java 调度
|
2月前
|
监控 安全 Java
在 Java 中使用线程池监控以及动态调整线程池时需要注意什么?
【10月更文挑战第22天】在进行线程池的监控和动态调整时,要综合考虑多方面的因素,谨慎操作,以确保线程池能够高效、稳定地运行,满足业务的需求。
119 38
|
2月前
|
Java
.如何根据 CPU 核心数设计线程池线程数量
IO 密集型:核心数*2 计算密集型: 核心数+1 为什么加 1?即使当计算密集型的线程偶尔由于缺失故障或者其他原因而暂停时,这个额外的线程也能确保 CPU 的时钟周期不会被浪费。
60 4
|
2月前
|
Java
线程池七大参数
核心线程数:线程池中的基本线程数量 最大线程数:当阻塞队列满了之后,逐一启动 最大线程的存活时间:当阻塞队列的任务执行完后,最大线长的回收时间 最大线程的存活时间单位 阻塞队列:当核心线程满后,后面来的任务都进入阻塞队列 线程工厂:用于生产线程
|
2月前
|
Java
线程池内部机制:线程的保活与回收策略
【10月更文挑战第24天】 线程池是现代并发编程中管理线程资源的一种高效机制。它不仅能够复用线程,减少创建和销毁线程的开销,还能有效控制并发线程的数量,提高系统资源的利用率。本文将深入探讨线程池中线程的保活和回收机制,帮助你更好地理解和使用线程池。
94 2
|
2月前
|
Prometheus 监控 Cloud Native
在 Java 中,如何使用线程池监控以及动态调整线程池?
【10月更文挑战第22天】线程池的监控和动态调整是一项重要的任务,需要我们结合具体的应用场景和需求,选择合适的方法和策略,以确保线程池始终处于最优状态,提高系统的性能和稳定性。
339 2
|
10天前
|
NoSQL Redis
单线程传奇Redis,为何引入多线程?
Redis 4.0 引入多线程支持,主要用于后台对象删除、处理阻塞命令和网络 I/O 等操作,以提高并发性和性能。尽管如此,Redis 仍保留单线程执行模型处理客户端请求,确保高效性和简单性。多线程仅用于优化后台任务,如异步删除过期对象和分担读写操作,从而提升整体性能。
33 1
|
3月前
|
存储 消息中间件 资源调度
C++ 多线程之初识多线程
这篇文章介绍了C++多线程的基本概念,包括进程和线程的定义、并发的实现方式,以及如何在C++中创建和管理线程,包括使用`std::thread`库、线程的join和detach方法,并通过示例代码展示了如何创建和使用多线程。
62 1

相关实验场景

更多