在Java中,线程是不能缺少的,而线程池可以最大限度的方便我们使用线程处理任务,你们知道线程池都有哪几种吗?都有什么用呢?下面就让小编带大家来了解一下吧。
什么是线程池
线程池是一种多线程处理形式,处理过程中会将任务添加到队列,然后在创建线程后自动启动这些任务。在线程池中,每个线程都会使用默认的堆栈大小,以默认的优先级运行,并处在多线程单元中,如果某个线程在托管代码中空闲的话,线程池就会插入一个其他辅助线程来使所有处理器保持繁忙。如果所有线程池都始终保持繁忙,但队列中始终包含挂起的工作的话,线程池将在一段时间后辅助线程的数目永远不会超过最大值。超过最大值的线程可以排队,但他们会等到其他线程完成后才能启动。
线程池工作机制
在线程池的编程模式下,任务是提交给整个线程池,而不是直接提交给某个线程,线程池在拿到任务后,就在内部寻找是否有空闲的线程,如果有,则将任务交给某个空闲的线程。一个线程同时只能执行一个任务,但可以同时向一个线程池提交多个任务。
为什么使用线程池
多线程运行期间,系统会不断的启动和关闭新线程,成本非常高,会过渡消耗系统资源,以及过渡切换线程的危险,从而可能导致系统资源的崩溃。线程池可以有效缓解这种情况。
Java都有哪些线程池
1. newCachedThreadPool可缓存线程池程
newCachedThreadPool,是一种线程数量不定的线程池,其最大线程数为Integer.MAX_VALUE,这个数是很大的,一个可缓存线程池,如果线程池长度超过处理需要,就会回收空闲线程,如果没有可回收线程,就会新建线程。但是,在线程池中的空闲线程都是有时间限制的,时长是60秒,超过60秒闲置线程就会被回收。调用execute将重用以前构造的线程(如果线程可用)。这类线程池比较适合执行大量的耗时较少的任务,当整个线程池都处于闲置状态时,线程池中的线程都会超时被停止。
2. newFixedThreadPool 定长线程池
newFixedThreadPool 会创建一个指定工作线程数量的线程池,每当提交一个任务就创建一个工作线程,当线程 处于空闲状态时,它们不会被回收,除非线程池关闭了,如果工作线程数量达到线程池初始的最大数,则会将提交的任务存入到池队列中。由于newFixedThreadPool只有核心线程,并且这些核心线程不会被回收,这样它才能更加快速底相应外界的请求。
3. newScheduledThreadPool 定长线程池
newScheduledThreadPool 线程池,它的核心线程数量是固定的,而非核心线程数是没有限制的,并且当非核心线程闲置时会被立即回收,它可安排给定延迟后运行命令或者定期地执行。这类线程池主要用于执行定时任务和具有固定周期的重复任务。
4. newSingleThreadExecutor 单线程化线程池
newSingleThreadExecutor这类线程池内部只有一个核心线程,以无界队列方式来执行该线程,这使得这些任务之间不需要处理线程同步的问题,它确保所有的任务都在同一个线程中按顺序中执行,并且可以在任意给定的时间不会有多个线程是活动的。
以上就是本篇文章的所有内容了,更多关于Java一些知识问答的内容,请持续关注本站吧。