程序员谈话系列——线程池的魅力

一,为什么要使用线程池呢?

池化技术就是为了减少每次获取资源的消耗,提高对资源的利用率。线程池提供了一种限制和管理资源,每个线程池维护一些基本的统计信息。

1.降低了资源消耗,通过重复利用已创建的线程减低线程创建和销毁的消耗。

2.提高响应的速度。当任务到达时,任务可以不需要等到线程创建就能立即执行。

3.提高线程的可管理性。线程是稀缺资源,如果无限制的创建,不仅会消耗系统资源,还会降低系统的稳定性,使用线程池可以进行统一的分配,调优和监控。

二,使用Runnable接口和Callable接口的区别。

1)Runnable不支持返回结果或抛出检查异常,但是Callable支持。所以不需要返回结果的时候使用Runnable接口。使用工具类Executors可以实现Runnable对象和Callable对象之间的相互转换。(Executors.callable(Runnabletask))或Excutors.callable(Runnable task,Object resule)。

三,执行execute()方法和submit()方法的区别是什么?

1)execute()方法用于提交不需要返回值的任务,所以无法判断任务是否执行成功与否

2)submit()方法用于提交需要返回值的任务,线程池会返回一个Future类型的对象,通过这个Future对象可以判断任务是否执行成功,并且可以通过Future的get()方法来获取返回值,get()方法会阻塞当前线程直到任务完成,而使用get(long timeout,TimeUnit unit)方法则会阻塞当前线程一段时间后立即返回,这时候有可能任务没有执行完。

四,如何创建一个线程池?

最好使用ThreadPoolExecutor创建,因为Executors方法里面有FixedThreadPool等很容易导致oom。

方法一:通过构造方法实现。

方法二:通过Executor框架的工具类Executors来实现我们可以创建三种类型的ThreadPoolExecutor:

FixedThreadPool:返回一个固定线程数量的线程池。

SingleThreadExecutor:返回一个只有一个线程的线程池。

CachedThreadPool:该方法返回一个根据实际情况调整线程数量的线程池,线程数量不确定。

ThreadPoolExcutor中3个重要的参数:

corePoolSize:最小可以同时运行的线程数量。

maximumPoolSize:最大容量

workQueue:判断新任务是否达到核心线程数。

posted @ 2020-03-02 21:27  欲码则码  阅读(130)  评论(0编辑  收藏  举报