目录
概念
什么是线程?
是操作系统能够进行运算调度的最小单位。(例如: cpu 对前端发往后端的一个请求的处理叫一个线程)
什么是线程池?
百度百科:线程池
线程池(Thread Pool)是一种基于池化思想管理线程的工具,它维护多个线程。
线程池出现背景
1、高并发、处理时间长、效率低
2、摩尔定律:处理器的性能大约每两年翻一倍(硬件成本降低)
线程池原理图
线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。每个线程都使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。.
JAVA提供线程池
Java通过Executors提供四种线程池,分别为:
newCachedThreadPool
可缓存线程池,如果线程池长度超过处理需要,可灵活回收空闲线程,若无可回收,则新建线程。newFixedThreadPoo
创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待。
newScheduledThreadPool
创建一个定长线程池,支持定时及周期性任务执行。
newSingleThreadExecutor
单线程化的线程池,用唯一的工作线程来执行,任务按照指定顺序(FIFO,LIFO,优先级)执行。
线程池参数
1 、 corePoolSize (线程池基本大小)必须大于或等于 0 ;
2 、 maximumPoolSize (线程池最大大小)必须大于或等于 1 ,必须大于或等 等于 corePoolSize ;
3 、 keepAliveTime (线程存活保持时间)必须大于或等于 0 ;
4 、 unit (存活时间的单位)
5 、 workQueue (任务队列)不能为空;
6 、 threadFactory (线程工厂)不能为空,默认为 DefaultThreadFactory 类
7 、 handler (线程饱和策略)不能为空,默认策略ThreadPoolExecutor.AbortPolicy