博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
面试刷题20:并发包中的线程池有哪些?
阅读量:4211 次
发布时间:2019-05-26

本文共 1714 字,大约阅读时间需要 5 分钟。

image.png

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;

image.png

线程池参数

线程池的结构如下图:
image.png

file

5中类型的线程池尽量避免使用前三种,应该自己精确设定线程池的这6个参数。
原因如下:
1,newSingleThreadExecutor(),工作队列是无界队列,工作队列超出极限容易引发内存溢出的问题。

public static ExecutorService newSingleThreadExecutor() {        return new FinalizableDelegatedExecutorService            (new ThreadPoolExecutor(1, 1,                                    0L, TimeUnit.MILLISECONDS,                                    new LinkedBlockingQueue
())); }
2, newFixedThreadPool(int) ,工作队列是无界队列,超出极限容易引发内存溢出的问题;
public static ExecutorService newFixedThreadPool(int nThreads) {        return new ThreadPoolExecutor(nThreads, nThreads,                                      0L, TimeUnit.MILLISECONDS,                                      new LinkedBlockingQueue
()); }

3, newCacheThreadPool(),最大线程数太大,容易引起线程泄露;

public static ExecutorService newCachedThreadPool() {        return new ThreadPoolExecutor(0, Integer.MAX_VALUE,                                      60L, TimeUnit.SECONDS,                                      new SynchronousQueue
()); }

小结

本篇回答了java常见的线程池,以及分析了线程池的参数的含义,以及线程池处理模型;
然后简要介绍了如何调优线程池的参数,以及使用的注意问题。

image.png

原创不易,转载请注明出处,让我们互通有无,共同进步,欢迎多沟通交流

你可能感兴趣的文章
HTML条件注释
查看>>
Putty远程服务器的SSH经验
查看>>
内核态与用户态
查看>>
使用mingw(fedora)移植virt-viewer
查看>>
趣链 BitXHub跨链平台 (4)跨链网关“初介绍”
查看>>
C++ 字符串string操作
查看>>
MySQL必知必会 -- 了解SQL和MySQL
查看>>
MySQL必知必会 -- 使用MySQL
查看>>
MySQL必知必会 -- 数据检索
查看>>
MySQL必知必会 -- 排序检索数据 ORDER BY
查看>>
MySQL必知必会 -- 数据过滤
查看>>
MYSQL必知必会 -- 用通配符进行过滤
查看>>
MYSQL必知必会 -- 用正则表达式进行搜索
查看>>
MySQL必知必会 -- 创建计算字段
查看>>
MySQL必知必会 -- 使用数据处理函数
查看>>
MySQL必知必会 -- 数据汇总
查看>>
MySQL必知必会 -- 子查询的使用
查看>>
POJ 3087 解题报告
查看>>
POJ 2536 解题报告
查看>>
POJ 1154 解题报告
查看>>