1.Executors直接创建线程池
2.ThreadPoolExecutor构造方法创建ThreadPoolExecutor构造方法创建
3.spring的ThreadPoolTaskExecutor方式(常用)
线程池的参数
corePoolSize:核心线程数,即线程池中的最小线程数。即使线程处于空闲状态,也不会被回收。
只有当线程数大于核心线程数时,空闲线程才会被回收。
maximumPoolSize:最大线程数,线程池能够容纳的最大线程数。当队列满了,
并且已经创建的线程数小于maximumPoolSize,线程池会再创建新的线程执行任务。
keepAliveTime:线程空闲时间,当线程空闲时间达到keepAliveTime时,会被回收。直到线程数达到corePoolSize。
workQueue:存储待执行任务的队列。
threadFactory:用于创建新线程的线程工厂。
handler:拒绝策略,当队列和线程池都满了,说明线程池已经饱和,那么必须采取一种策略处理提交的新任务。
最大线程数和核心线程数的区别在于:
核心线程数:这是线程池启动后默认存在的线程数量,即使这些线程处理完任务后也不会被销毁,除非设置了允许核心线程超时。
最大线程数:这是线程池能够容纳的最大线程数量。当队列满了,且当前线程数量小于最大线程数,
线程池会创建新的线程来处理任务。如果当前线程数量已经达到最大线程数,则会根据拒绝策略来处理新任务。
简而言之,核心线程数是线程池的最小大小,而最大线程数是线程池的最大大小。