当前位置: 首页 > article >正文

面试小札:线程池

 

1 什么是线程池

2 线程池如何工作的?

3 线程和进程有什么区别?

4 描述线程池的工作流程。

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

6 threadpool executor核心参数有哪些?

 

一、什么是线程池

 

线程池是一种多线程处理形式,它可以有效地管理和复用线程,避免频繁地创建和销毁线程所带来的性能开销。

 

二、线程池如何工作

 

线程池创建:首先创建一个线程池,指定一些参数,如核心线程数、最大线程数、线程空闲时间等。

任务提交:当有新的任务提交到线程池时,如果线程池中的线程数小于核心线程数,会创建新的线程来执行任务。

线程复用:如果线程数已经达到核心线程数,新的任务会被放入任务队列等待线程空闲时执行。

线程扩充:当任务队列已满,且线程数小于最大线程数,会创建新的线程来执行任务。

线程回收:当线程空闲时间超过指定的时间,且线程数大于核心线程数,多余的线程会被回收。

 

三、线程和进程的区别

 

资源分配:进程拥有独立的地址空间和资源,而线程共享所属进程的资源。

调度:进程切换开销较大,线程切换开销较小。

通信:进程间通信较为复杂,线程间通信相对简单。

健壮性:一个进程崩溃一般不会影响其他进程,而一个线程崩溃可能导致整个进程崩溃。

 

四、线程池的工作流程

 

创建线程池:通过指定核心线程数、最大线程数、工作队列等参数来创建线程池。

提交任务:调用线程池的 execute 或 submit 方法提交任务。

分配线程执行任务:如果有空闲线程,直接分配执行任务;如果没有空闲线程且线程数小于核心线程数,创建新线程执行;如果线程数达到核心线程数,任务放入工作队列等待。

处理工作队列中的任务:当有线程空闲时,从工作队列中获取任务执行。

扩展线程:如果工作队列已满且线程数小于最大线程数,创建新线程执行任务。

回收线程:当线程空闲时间超过设定值且线程数大于核心线程数,回收多余线程。

 

五、线程池的拒绝策略

 

 AbortPolicy :直接抛出 RejectedExecutionException 异常,阻止系统正常运行。

 CallerRunsPolicy :将任务回退到调用者所在线程执行。

 DiscardOldestPolicy :丢弃队列中最旧的未处理任务,然后重新尝试执行当前任务。

 DiscardPolicy :直接丢弃任务,不做任何处理。

 

六、 ThreadPoolExecutor 核心参数

 

 corePoolSize :核心线程数,即使线程空闲也会保留的线程数。

 maximumPoolSize :最大线程数。

 keepAliveTime :线程空闲时间,超过该时间空闲线程会被回收。

 unit : keepAliveTime 的时间单位。

 workQueue :用于保存等待执行任务的阻塞队列。


http://www.kler.cn/a/427603.html

相关文章:

  • 下载谷歌浏览器的官方离线安装包
  • 【论文解读】MD-VQA: Multi-Dimensional Quality Assessment for UGC Live Videos
  • TCP编程案例
  • 基于Matlab的卷积神经网络(CNN)苹果分级检测系统
  • 视频编辑技术:一键生成混剪视频的AI技术应用
  • scss文件内引入其他scss文件报错
  • 十九(GIT2)、token、黑马就业数据平台(页面访问控制(token)、首页统计数据、登录状态失效)、axios请求及响应拦截器、Git远程仓库
  • Nginx日常运维方法Linux版
  • 【LeetCode】80.删除有序数组中的重复项II
  • 目前国内【齿轮检测仪】行业整体较为分散,行业竞争日趋激烈
  • 斗地主之顺子(Java Python JS C++ C )
  • 《Java核心技术I》线程局部变量
  • python包之click
  • 使用xtrabackup对MySQL5.7数据库进行物理备份
  • 四个人排序——c++选择结构提高
  • 【调试工具】USB 转 UART 适配器(USB 转 TTL)
  • 华为 Mate 70 系列智能手机将运行不兼容 Android 的鸿蒙
  • 深入解析汽车对自行车手纵向成人碰撞测试(CBLA)
  • CSS3 动画详解,介绍、实现与应用场景详解
  • Alogrithm:老鼠走迷官(一)