线程池的处理流程于核心参数
线程池的处理流程如下:
- 线程池判断核心线程池里的线程是否都在执行任务。如果不是,则创建一个新的工作线程来执行任务。如果核心线程池里的线程都在执行任务,则进入下一流程。
- 线程池判断工作队列是否已满。如果工作线程队列没有满,则将新提交的任务存储在这个工作队列里。如果工作队列满了,则进入下一流程。
- 线程池判断线程池的线程是否都处于工作状态。如果没有,则创建一个新的工作线程来执行任务。如果满了,则交给饱和策略来处理这个任务。
ThreadPoolExecutor 执行 execute 方法分为以下四种情况:
- 如果当前运行的线程少于 corePoolSize,则创建新线程来执行任务。
- 如果运行的线程数量大于或等于 corePoolSize,则将任务加入 BlockingQueue。
- 如果无法将任务加入到 BlockingQueue,则创建新的线程来处理任务。
- 如果创建新线程将使当前运行的线程数量超出 maximumPoolSize,任务将被拒绝,并调用 RejectedExecutionHandler.rejectedExecution() 方法。
线程池核心参数:
corePoolSize(线程池基本大小):当提交一个任务到线程池是,线程池会创建一个线程来执行任务,即使其他空闲的基本线程能执行新任务也创建线程,等到需要执行的任务数大于线程池基本大小时就不再创建。
runnableTaskQueue(任务队列):用于保存等待执行的任务的阻塞队列。
- ArrayBloc