线程题---什么是线程池?

线程题—什么是线程池?

概念性的知识,上来就是整,读个三五遍熟悉一下,然后就背下来,简单、粗暴、有效。

在面向对象编程中,创建和销毁对象是非常浪费时间的,因为创建一个对象要获取内存资源或者其他更多的资源。在java中更是如此,因为虚拟机将试图跟踪每一个对象,以便于当对象销毁时,进行垃圾回收,所以尽量少的创建和回收垃圾,是提高服务程序效率的一个重要手段,特别是一些很消耗资源的对象的创建和销毁,这就“池化技术”诞生的原因。

线程池,顾名思义就是实现创建出很多个可执行线程的池子(容器),需要的时候从池子中获取线程,不需要自行创建,使用完毕后,再把它放回池子中,不需要销毁。从而减少了创建和销毁对象的开销。

Executor 接口定义一个执行线程的工具。他的子类型是一个,线程池接口ExecutorService。要配置一个线程池是很复杂的,因此,Executors提供了静态工厂方法,生成一些常用的线程池。

newSingleTreadExecutor:
创建一个单线程的线程池。这个线程池只有一个线程在工作,也就是想当于单线程串行执行所有任务。如果这个唯一的线程因为异常结束,那么会有一个新的线程来替代它。因此线程池保证所有任务的执行顺序按照任务提交的顺序执行。

newfixedThreadPool:
创建固定大小的线程池。每次提交一个任务就创建一个线程,直到线程数达到了线程池的最大数。线程池达到最大值后就会维持不变,如果某个线程因为执行异常而结束,那么线程池会补充一个新的线程。

newCachedThreadPool:
创建一个可缓存的线程池。如果线程池的大小超过了处理任务所需要的线程,那么就会回收部分空间(60秒不执行任务)的线程,当任务数量增加时,此线程池又可以智能的添加新线程来处理任务。此线程池不会对线程大小做限制,线程池大小完全取决于操作系统(或者说jvm)能够创建多少。

newScheduledThreadPool:
创建一个大小无限的线程池。此线程池支持定时以及周期性执行任务的需求。

通过Executors工具创建线程池并使用线程池执行的线程的代,一般如果在服务器上使用线程池,强烈建议使用newFixedThreadPool方法来创建线程池,这样能获得更好的性能。

此知识点为看《北京尚学堂》视频课后的总结。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值