JDK中的线程池和工作机制
初始化
线程池都是用ThreadPoolExecutor来初始化。
jdk预定义了一些线程池模板,可以用Executors来获取。
各个参数的含义
corePoolSize:线程池初始化时,核心线程数大小。
maximumPoolSize:线程池最大线程数。当核心线程用完了,队列里也装满了,会创建新的线程来执行任务,但不能超过最大线程数。
keepAliveTime:线程空闲下来后,线程的存活时间,只有线程数>corePoolSize时才有用。
unit:空闲时间的单位
workQueue:核心线程数满了后,装任务的队列。建议用有界队列,不然会有撑爆内存的风险。
threadFactory:线程工厂类,可以自定义线程的属性。
handler:拒接策略。
AbortPolicy :直接抛出异常,默认;
CallerRunsPolicy:用调用者所在的线程来执行任务
DiscardOldestPolicy:丢弃阻塞队列里最老的任务,队列里最靠前的任务
DiscardPolicy :当前任务直接丢弃
实现自己的饱和策略,实现RejectedExecutionHandler接口即可
提交任务
execute():不用返回值
submit(): 需要返回值
关闭线程池
shutdown(): 设置线程池状态,只有没有任务的线程会立即中断
shutdownNow