java多线程线程池_Java多线程——线程池(ThreadPool)
我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题:
如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间。
那么有没有一种办法使得线程可以复用,就是执行完一个任务,并不被销毁,而是可以继续执行其他的任务?
对,没错!就是我们的ThreadPool!
让我们来看一下ThreadPool的大概流程原理:
然后我们再来看一个有关的运用到线程池的打印实例,来体会一下线程池的妙用:
1 public classThreadPoolTest {2 public static voidmain(String[] args) {3 ExecutorService executorService = Executors.newFixedThreadPool(6);4 Tp tp= newTp();5 for (int i = 0; i < 12; i++) {6 executorService.submit(tp);7 }8 }9 }10
11 class Tp implementsRunnable{12 @Override13 public voidrun() {14 System.out.println(Thread.currentThread().getName());15 try{16 Thread.sleep(1000);17 } catch(InterruptedException e) {18 //TODO Auto-generated catch block
19 e.printStackTrace();20 }21 }22 }
其运行结果如下,我们可以看到,线程执行完后并没有被销毁,而是被复用了!并且调用的sleep()方法让线程打印完后休眠一秒,因此结果1-6号线程各打印两次。而如果不用线程池达到此效果,可能较为繁琐了
在代码中可以特别注意到第三行:
ExecutorService executorService = Executors.newFixedThreadPool(6);
Executors 提供四种线程池:(转自链接:https://www.jianshu.com/p/b8197dd2934c)
1)newCachedThreadPool 是一个可根据需要创建新线程的线程池,但是在以前构造的线程可用时将重用它们。对于执行很多短期异步任务的程序而言,这些线程池通常可提高程序性能。调用 execute() 将重用以前构造的线程(如果线程可用)。如果现有线程没有可用的,则创建一个新线程并添加到池中。终止并从缓存中移除那些已有 60 秒钟未被使用的线程。因此,长时间保持空闲的线程池不会使用任何资源。注意,可以使用 ThreadPoolExecutor 构造方法创建具有类似属性但细节不同(例如超时参数)的线程池。
2)newSingleThreadExecutor 创建是一个单线程池,也就是该线程池只有一个线程在工作,所有的任务是串行执行的,如果这个唯一的线程因为异常结束,那么会有一个新的线程来替代它,此线程池保证所有任务的执行顺序按照任务的提交顺序执行。
3)newFixedThreadPool 创建固定大小的线程池,每次提交一个任务就创建一个线程,直到线程达到线程池的最大大小,线程池的大小一旦达到最大值就会保持不变,如果某个线程因为执行异常而结束,那么线程池会补充一个新线程。
4)newScheduledThreadPool 创建一个大小无限的线程池,此线程池支持定时以及周期性执行任务的需求。
这里分享一个特别棒的可视化可直观感受四种线程池异同的文章:https://zhuanlan.zhihu.com/p/112527671
一个很重要的知识点——有关线程池的基本参数也摘于此
corePoolSize=>线程池里的核心线程数量
maximumPoolSize=> 线程池里允许有的最大线程数量
keepAliveTime=>空闲线程存活时间
unit=>keepAliveTime的时间单位,比如分钟,小时等
workQueue=> 缓冲队列
threadFactory=>线程工厂用来创建新的线程放入线程池
handler=>线程池拒绝任务的处理策略,比如抛出异常等策略
java多线程线程池_Java多线程——线程池(ThreadPool)相关推荐
- java线程池_Java多线程并发:线程基本方法+线程池原理+阻塞队列原理技术分享...
线程基本方法有哪些? 线程相关的基本方法有 wait,notify,notifyAll,sleep,join,yield 等. 线程等待(wait) 调用该方法的线程进入 WAITING 状态,只有等 ...
- java 多线程池_Java ThreadPoolExecutor线程池 同时执行50个线程
最近项目上有个需求,需要从FTP服务器中下载大批量的数据文件,然后解析该数据文件进行入库,数据库为oracle,最后在通过web工程,以报表和图表的形式进行展现. 这些批量的数据文件为纯文本文件,每天 ...
- java 多线程使用线程池_Java多线程:如何开始使用线程
java 多线程使用线程池 什么是线程? (What is a Thread?) A thread is a lightweight process. Any process can have mul ...
- java多线池_java多线程之线程池
1.new Thread的弊端 执行一个异步任务你还只是如下new Thread吗? new Thread(new Runnable() { @Override public void run() { ...
- java线程组 线程池_JAVA多线程(三)-----线程组、线程池和线程相关类
一.线程组和未处理的异常 Thread类提供了如下几个构造器来设置新创建的线程属于哪个线程组: Thread(ThreadGroup group,Runnable target):以target的ru ...
- java定时线程池_java 定时器线程池(ScheduledThreadPoolExecutor)的实现
前言 定时器线程池提供了定时执行任务的能力,即可以延迟执行,可以周期性执行.但定时器线程池也还是线程池,最底层实现还是ThreadPoolExecutor,可以参考我的另外一篇文章多线程–精通Thre ...
- java线程入门_java多线程快速入门(一)
1.什么是进程 比如:QQ.QQ游戏.eclipse都是进程,可以通过任务管理器查看进程 2.进程和线程区别 线程是进程的一部分,一个进程可以包含多个线程,一个线程只能属于一个进程 进程是所有线程的集 ...
- java 线程 组成_java多线程
一:基本知识点 1.1线程与进程区别: 1.进程是资源分配的最小单位,线程是CPU调度的最小单位 2.一个进程由一个或多个线程组成 3.进程之间相互独立,每个进程都有独立的代码和数据空间,但同一进程下 ...
- thread.sleep是让哪个线程休眠_java多线程必看:java线程的生命周期
点击蓝字 关注我们 线程是一个动态执行的过程,它也有从创建到死亡的过程.线程的几种状态 在 Thread 类中,有一个枚举内部类: 上面的信息以图片表示如下: 第一张图: 第二张图:把等待.计时等待. ...
最新文章
- 在Python中访问字典中的任意元素
- 背口诀14天精通c语言pdf下载,C语言必背18个经典程序
- iOS网络 把数据存入钥匙串
- Win7玩CF,不能全屏的解决方法...
- mysql集群软件有哪些_浅谈数据库集群软件优缺点有哪些
- 电大计算机考试题目excel,电大计算机考试复习题EXCEL部分
- 西安石油大学计算机基础考试试题,2017年西安石油大学计算机学院824计算机组成原理考研题库...
- oracle修改字符集_oracle修改数据库字符集
- 建立项目接口文档_一个 SpringBoot 项目该包含哪些?
- dede新增字段调用方法
- 根据银行卡号获取对应的银行信息
- Ubuntu系统报错
- jeecgboot示例程序
- 新生代公链再攻「不可能三角」
- 数据库大量数据操作中事务优化方案
- VirtualBox 虚拟机里网络很慢的解决方法
- Degis 是第一个基于 Avalanche 的保险协议,测试得空投
- 修改电脑qq的聊天背景
- 外贸收款方式精辟分析 1
- 机票信息全方位实时采集方案
热门文章
- 罗永浩回应“调侃”俞敏洪转行做直播;苹果3月9日举行春季发布会;CentOS推出新车载Linux发行版 | 极客头条...
- 超越Tiny-YOLO V4,全新设计轻量化YOLO模型实现边缘实时检测!!!
- 微软、阿里抢占开源一线,JavaScript、Python 备受热捧,GitHub 2020 数字洞察报告揭晓!...
- 腾讯、字节跳动展开拉锯战;网易云音乐称酷狗抄袭;谷歌不再开发云游戏 | 极客头条...
- Python爬取B站弹幕+Gephi梳理主线剧情
- 2020腾讯全球数字生态大会:产业互联网战略升级,数字优先引领未来经济发展
- 魔幻的2020年,请程序员们收下这份秋招建议!
- 员工一言不合就离职怎么办?用 Python 写了个员工流失预测模型
- 华为回应美新规:不涉及产品买卖;微软 GitHub 帐户疑被黑;GCC 10.1 发布 | 极客头条...
- 吊打面试官系列:你会「递归」么?