线程池
结构图
线程池是一套围绕着核心线程、非核心线程、等待队列的任务调度框架。
默认情况,线程池主要结构如下:
漫画 Java 线程池的工作机制corePoolSize
核心线程数
当前线程池中运行的线程数量还没有达到 corePoolSize 大小时,线程池会将任务直接提交给核心线程执行
漫画 Java 线程池的工作机制BlockingQueue
等待队列
如果当前线程池中运行的线程数量已经达到 corePoolSize ,新提交的任务会被加入到 等待队列 中
漫画 Java 线程池的工作机制直到某一个" 核心线程 "执行任务完毕,处于空闲状态,线程池会 等待队列 中取出一个新的任务执行
漫画 Java 线程池的工作机制maximumPoolSize
最大线程数量
当线程数大于 corePoolSize 数量,并且等待队列已满,但是还没有达到最大线程数 maximumPoolSize ,则线程池会创建新的" 非核心线程 "来执行任务
漫画 Java 线程池的工作机制R ejectedExecutionException
任务拒绝策略
如果提交的任务,无法被核心线程直接执行,又无法加入等待队列,又无法创建“非核心线程”直接执行,线程池将根据拒绝处理器定义的策略处理这个任务
漫画 Java 线程池的工作机制
网友评论