Java线程——线程池
一、什么是线程池
线程池是一种多线程处理形式,处理过程中将任务添加到队列,然后在创建线程后自动启动这些任务。线程池线程都是后台线程。每个线程都使用默认的堆栈大小,以默认的优先级运行,并处于多线程单元中。如果某个线程在托管代码中空闲(如正在等待某个事件),则线程池将插入另一个辅助线程来使所有处理器保持繁忙。如果所有线程池线程都始终保持繁忙,但队列中包含挂起的工作,则线程池将在一段时间后创建另一个辅助线程但线程的数目永远不会超过最大值。超过最大值的线程可以排队,但他们要等到其他线程完成后才启动。
二、线程池的创建
线程池的接口都是 ExecutorService,常用的有这几种方法:
1、newFiexedThreadPool(int Threads):创建固定数目线程的线程池。
2、newCachedThreadPool():创建一个可缓存的线程池,调用execute 将重用以前构造的线程(如果线程可用)。如果没有可用的线程,则创建一个新线程并添加到池中。终止并从缓存中移除那些已有 60 秒钟未被使用的线程。
3、newSingleThreadExecutor()创建一个单线程化的 Executor。
4、newScheduledThreadPool(int corePoolSize)创建一个支持定时及周期性的任务执行的线程池,多数情况下可用来替代 Timer 类。
三、newThreads 和 pool
new Thread 是创建线程的方法,它可以 new 一个线程,但是每次需要新的线程的时候,都需要重新 new 一个线程,在程序中你可以发现每次 new Thread 新建对象性能差而且线程缺乏统一管理,可能无限制新建线程,相互之间竞争,及可能占用过多系统资源导致死机或 oom。
相比于 new Thread 来说 pool 的方式好处就太多了,但是线程池永远都是默认存在的,想要结束线程池得自己手动结束,也就是返还线程池并且shutdown。