创建java线程池有以下几种方式:
1.newSigleThreadExecutor
创建一个单线程线程池。这个线程池只有一个线程在工作,也就相当于单线程串行执行所有任务,如果这个唯一线程因为异常结束,那么就会有一个新的线程去代替他。此线程池保证所有任务的执行顺序按照任务的提交顺序执行
2.newFixedThreadPool
创建固定大小的线程池。每次提交一个任务就是创建一个线程,直到线程达到线程池最大大小。线程池的大小一担达到最大值就会保持不变,如果某个线程因为执行一场而结束,这个线程池补充一个新线程
3.newCatchThreadPool
创建一个可缓存的线程池,如果线程池的大小超过了处理任务所需要的线程,那么机会回收部分空闲(60s不执行的线程)的线程,如果任务增加时,此线程又可以智能的添加新线程来处理任务,此线程池不会对线程池大小做限制,线程池的大小有依赖于操作系统(或者JVM)能创建的最大线程池的大小
4.newScheduledThreadPool
创建一个大小不限的线程池,此线程池支持定时以及周期性执行任务需求
线程池都有哪些状态:
1.Running
状态说明:线程池处于Running状态时可以接受新的任务,以及对已添加的任务进行处理
状态切换:线程池的初始化状态是Running,换句话说,线程池一旦被创建,就处于Running状态,并且线程池总是我0
2.SHUTDOWN
状态说明:此时线程池处于SHUtDOWN状态时,不在接受新任务,但能处理已添加的任务
状态切换:调用线程池SHUTDOWN()接口时,线程池由RUNNING->SHUTDOWN
3. STOP
状态说明:线程池处STOP的状态下,不再接受任务,吧并且会中断正在处理的任务
状态切换:调用线程池SHUTDOWNNow()接口时,线程池由Running或者SHUTDOWN->STOP
4 .YIDING
状态说明:当所有的任务停止时,CTL记录的总数“任务量”为0,线程池就会变成TIDYING状态。当线程池变为TIDYING状态时,会执行子函数terminated(),terminated()在ThreadPoolExcutor类中为空,若是想在线程池变为TIDYING时,进行相应的处理,可以通过重载terminated()来实现
状态切换:当线程池哎SHUTDOWN状态下,阻塞队列为空并且线程池执行的任务也为空,就会由SHOWDOWN-》TIDYING当现在线程池为STOP状态下,线程池的执行为空时就会由STOP->TIDYING
4.TERMINATED
状态说明:线程池彻底终止,就变成了TERMINATED
状态切换:线程池处于TIDYING状态时,执行完terminated()以后就变成了TIDYING->TERMINATED