面试刷题20:并发包中的线程池有哪些?
2020-03-30 16:03:37来源:博客园 阅读 ()
面试刷题20:并发包中的线程池有哪些?
java提供的线程池可以简化线程管理,提高线程资源的利用率。
大家好,我是李福春,今天的题目是:
Java提供了哪些线程池?如何设置合适的线程池大小?
答:java.util.concurrent包中提供了5种线程池,从简单到复杂列举如下:
一,newSingleThreadExecutor() ,单线程池,任何时候工作线程都是1个,队列是无界队列保证任务的顺序执行;
二,newFixedThreadPool(int),固定数量的线程池,任何时候工作线程都是N,内部使用的无界队列;
三,newCachedThreadPool()缓存线程池,适合处理大量短时间执行的任务;
四,newWorkStealingPool(int)工作窃取线程池,java8引入,内部使用ForkJoinPool实现
五,newScheduledThreadPool(),适合处理定时或者周期性的任务
如何合理设置线程池大小?
需要综合计算任务的特点来。
cpu耗费较高的,核心线程数一般设置为N(cpu核心数)
等待任务较多的,核心线程数一般设置为 Ncpu利用率(1+平均等待时间/平均执行时间)
同时在使用线程池的时候,注意一下5点:
1, 避免任务堆积
2,避免过度扩展线程,以及避免线程泄露;
3,避免死锁,合理使用各种锁;
4,避免使用ThreadLocal;
线程池参数
线程池的结构如下图:
5中类型的线程池尽量避免使用前三种,应该自己精确设定线程池的这6个参数。
原因如下:
1,newSingleThreadExecutor(),工作队列是无界队列,工作队列超出极限容易引发内存溢出的问题。
public static ExecutorService newSingleThreadExecutor() {
return new FinalizableDelegatedExecutorService
(new ThreadPoolExecutor(1, 1,
0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>()));
}
2, newFixedThreadPool(int) ,工作队列是无界队列,超出极限容易引发内存溢出的问题;
public static ExecutorService newFixedThreadPool(int nThreads) {
return new ThreadPoolExecutor(nThreads, nThreads,
0L, TimeUnit.MILLISECONDS,
new LinkedBlockingQueue<Runnable>());
}
3, newCacheThreadPool(),最大线程数太大,容易引起线程泄露;
public static ExecutorService newCachedThreadPool() {
return new ThreadPoolExecutor(0, Integer.MAX_VALUE,
60L, TimeUnit.SECONDS,
new SynchronousQueue<Runnable>());
}
小结
本篇回答了java常见的线程池,以及分析了线程池的参数的含义,以及线程池处理模型;
然后简要介绍了如何调优线程池的参数,以及使用的注意问题。
原创不易,转载请注明出处。
原文链接:https://www.cnblogs.com/snidget/p/12599523.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 2020年深圳中国平安各部门Java中级面试真题合集(附答案) 2020-06-11
- JVM常见面试题解析 2020-06-11
- 作为一个面试官,我想问问你Redis分布式锁怎么搞? 2020-06-10
- 送你一份年薪百万的抖音Java岗内部面试题 2020-06-09
- 一口气说出 6种 延时队列的实现方案,面试稳稳的 2020-06-08
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash