一.线程池的简介
1.1为什么要创建线程池
程序中要短时间内创建大量线程任务,就会频繁的创建和销毁线程,这样就会导致给cpu产生大量的负担,于是我们可以提前创建一批线程存储起来,使用的时候,就不会频繁的创建和销毁,直接拿来用就可以了
1.2线程池的七个参数
核心线程数(corepoolsize)
最大线程数(maxnumpoolsize)
最大空闲时间(keepalivetime)
时间单位(timeunitunit)
阻塞队列(BlockingQueue workQueue)
线程工厂(threadfactory)
拒绝策略(RejectedExecutionHandler)
1.3线程池的创建方式
newCacheThreadPool,缓存的线程池,可以短期内处理大量短期的突发流量
最大线程数Integer-maxvalue(2的31次方)
存活时间 60秒
阻塞队列synchronous-Queue
newFixThreadPool 一种固定数量的线程池
特点:核心线程和最大数量都是一个固定值,任务较多,工作处理不过来,就会加入到阻塞队列里
newSingleThreadexecutor
只有一个工作的线程池,并且线程池的数量无法动态更改,保证所有的事务都按照fifo的方式顺序进行
newScheduleThreadPool
延迟线程池,实现任务的定时调度
newWorkStealingPool
1.8新加入的线程池,内部会构建一个forkjoinPool利用工作窃取的算法,并处理请求
他们都是通过executors创建,ThreadPoolexecutor最终实现