大家都说Timer不太好用,经常会遇到:如果前边的一个任务比较慢,超出了period,此时timer的下一次轮询也会延迟。

同事说ScheduleExecutorService可以避免该问题,我写个例子测试下:

package com.dx.testparallel;

import java.util.concurrent.Executors;
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.TimeUnit;; public class TestTimer {
public static void main(String[] args){
ScheduledExecutorService scheduledExecutorService=Executors.newScheduledThreadPool();
//Creates and executes a periodic action that becomes enabled
//first after the given initial delay, and subsequently with the
//given period; that is executions will commence after
//initialDelay then initialDelay+period, then initialDelay + 2 *
//period, and so on. If any execution of the task encounters an
//exception, subsequent executions are suppressed.
//Otherwise, the task will only terminate via cancellation or
//termination of the executor. If any execution of this task
//takes longer than its period, then subsequent executions may
//start late, but will not concurrently execute.
scheduledExecutorService.scheduleAtFixedRate(new TheTask(), ,, TimeUnit.MILLISECONDS);
}
}
package com.dx.testparallel;

import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.UUID; import javax.lang.model.element.VariableElement; public class TheTask implements Runnable{
@Override
public void run() {
Timestamp ts = new Timestamp(System.currentTimeMillis());
UUID uuid = UUID.randomUUID();
System.out.println("task"+uuid+" start:"+ts.toString()); // long num=0;
// for(int a=0;a<100000;a++){
// for(int i=0;i<1000000;i++){
// for(int j=0;j<1000000;j++){
// num= a*i*j;
// }
// }
// }
try {
Thread.sleep(2000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} ts = new Timestamp(System.currentTimeMillis());
System.out.println("task"+uuid+" end:"+ts.toString());
}
}

测试结果:为什么每次间隔时间是2s,而不是1s.

task418d088e-3288-4736-b40a-f3c4f496e2a2 start:2016-09-07 00:49:03.699
task418d088e-3288-4736-b40a-f3c4f496e2a2 end:2016-09-07 00:49:05.836
task741d2176-dbef-4f12-a73e-13a04ed5eb18 start:2016-09-07 00:49:05.836
task741d2176-dbef-4f12-a73e-13a04ed5eb18 end:2016-09-07 00:49:07.836
task96ebb6ca-c99b-482e-b608-bd560e89c7eb start:2016-09-07 00:49:07.836
task96ebb6ca-c99b-482e-b608-bd560e89c7eb end:2016-09-07 00:49:09.837
task1ce9f4bb-dd9e-4510-a697-73daef02fe6b start:2016-09-07 00:49:09.837
task1ce9f4bb-dd9e-4510-a697-73daef02fe6b end:2016-09-07 00:49:11.837
task0386a855-3e85-4d06-9d91-24abde228731 start:2016-09-07 00:49:11.837
task0386a855-3e85-4d06-9d91-24abde228731 end:2016-09-07 00:49:13.838
task886fe541-92d1-49bc-b5bd-2c425cf773ba start:2016-09-07 00:49:13.838
task886fe541-92d1-49bc-b5bd-2c425cf773ba end:2016-09-07 00:49:15.838
task460137d1-7daf-419b-b0d5-87f31833176c start:2016-09-07 00:49:15.838
task460137d1-7daf-419b-b0d5-87f31833176c end:2016-09-07 00:49:17.838
taskce78bffb-8151-46e8-81d9-57b01e9294a2 start:2016-09-07 00:49:17.838
taskce78bffb-8151-46e8-81d9-57b01e9294a2 end:2016-09-07 00:49:19.838
task1fad4b4f-4143-4098-943a-c894ad96ae58 start:2016-09-07 00:49:19.838
task1fad4b4f-4143-4098-943a-c894ad96ae58 end:2016-09-07 00:49:21.838
taskc5de2fab-0688-4410-9408-b0990cc76223 start:2016-09-07 00:49:21.838
taskc5de2fab-0688-4410-9408-b0990cc76223 end:2016-09-07 00:49:23.838
task7dccb95b-6088-4a5d-a2e0-edb4381f7d0c start:2016-09-07 00:49:23.838
task7dccb95b-6088-4a5d-a2e0-edb4381f7d0c end:2016-09-07 00:49:25.838
taskc05908b5-1bb2-496a-9ddc-c3939d783f2c start:2016-09-07 00:49:25.838
taskc05908b5-1bb2-496a-9ddc-c3939d783f2c end:2016-09-07 00:49:27.839
task251c4102-f214-4eb9-9e13-7ca7f2eb3362 start:2016-09-07 00:49:27.839
task251c4102-f214-4eb9-9e13-7ca7f2eb3362 end:2016-09-07 00:49:29.839
task645f6f0f-9d11-4545-be12-1feab67a6b06 start:2016-09-07 00:49:29.839
task645f6f0f-9d11-4545-be12-1feab67a6b06 end:2016-09-07 00:49:31.84
task82da54a5-6620-46f4-a840-10633555d2e8 start:2016-09-07 00:49:31.84
task82da54a5-6620-46f4-a840-10633555d2e8 end:2016-09-07 00:49:33.84
taskb33558c1-cb84-4724-85af-ac8060b169a0 start:2016-09-07 00:49:33.84

使用ScheduledExecutorService实现Timer的更多相关文章

  1. ScheduledExecutorService和timer的异同

    先来个传统的Timer的例子: package com.jerry.concurrency; import java.text.ParseException; import java.text.Sim ...

  2. 任务调度(四)——ScheduledExecutorService替代Timer,实现多线程任务调度

    上篇博文<任务调度(三)--Timer的替代品ScheduledExecutorService简介>已经对ScheduledExecutorService做了简介.事实上使用Schedul ...

  3. java定时任务Timer与ScheduledExecutorService<转>

    在我们编程过程中如果需要执行一些简单的定时任务,无须做复杂的控制,我们可以考虑使用JDK中的Timer定时任务来实现.下面LZ就其原理.实例以及Timer缺陷三个方面来解析java Timer定时器. ...

  4. 详解java定时任务---Timer篇

    一.简介      在java的jdk中提供了Timer.TimerTask两个类来做定时任务. Timer是一种定时器工具,用来在一个后台线程计划执行指定任务,而TimerTask一个抽象类,它的子 ...

  5. 线程 Timer TimerTask 计时器 定时任务 MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...

  6. 详解java定时任务

    在我们编程过程中如果需要执行一些简单的定时任务,无须做复杂的控制,我们可以考虑使用JDK中的Timer定时任务来实现.下面LZ就其原理.实例以及Timer缺陷三个方面来解析JavaTimer定时器. ...

  7. Java 四种线程池newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor

    介绍new Thread的弊端及Java四种线程池的使用,对Android同样适用.本文是基础篇,后面会分享下线程池一些高级功能. 1.new Thread的弊端执行一个异步任务你还只是如下new T ...

  8. Java四种线程池

    Java四种线程池newCachedThreadPool,newFixedThreadPool,newScheduledThreadPool,newSingleThreadExecutor 时间:20 ...

  9. Java(Android)线程池

      1.new Thread的弊端执行一个异步任务你还只是如下new Thread吗? new Thread(new Runnable() { @Override public void run()  ...

随机推荐

  1. Codeforces Round #199 (Div. 2) E. Xenia and Tree

    题目链接 2了,差点就A了...这题真心不难,开始想的就是暴力spfa就可以,直接来了一次询问,就来一次的那种,TLE了,想了想,存到栈里会更快,交又TLE了..无奈C又被cha了,我忙着看C去了.. ...

  2. UITableView常见 UI 问题总结

    一,经历 1.让 group 形式的UITableView的单元格也可以修改separatorStyle属性来设置. 2.修改group形式的UITableView的 cell 之间的间距,可以更改s ...

  3. 内存和flash存储的区别

    http://bbs.21ic.com/icview-202550-1-1.html 一.内存 我们一般说的内存指的是DRAM,其主要特点是断电会丢失数据,可读写 二.ROM 断电不会丢失数据,数据只 ...

  4. 在WeX5中导入项目

    在WeX5中导入项目 首先右击,选择[导入]--[导入] 得到如下的对话框,选择[现有项目到工作空间中] 在导入对话框中选择相应的根目录,选择相应的项目,确定 点击完成即可.这样一个项目就被导入到了W ...

  5. linux下搭建svn代码库

    1.安装svn客户端 2.创建svn代码库 1.安装svn客户端 1.1.使用命令安装 1)CentOS $ yum install subversion 2)ubuntu sudo apt-get ...

  6. CSS中id与class命名规则及编码最佳习惯

    一.用class_name方式写类名. 以前喜欢用class-name写,不过好像两样也没什么差别.但我比较反对用className写类名,因为始终对浏览器大小写敏感的问题抱有怀疑态度.但是id我会写 ...

  7. [zt] ROI (Region of Interest) 感兴趣区域 OpenCV

    在以前介绍IplImage结构的时候,有一个重要的参数——ROI.ROI全称是”Region Of Interest”,即感兴趣的区域.实际上,它是IPL/IPP(这两个是Inter的库)结构IplR ...

  8. android-ListView控件的使用

    一.深刻理解ListView 1.职责:将数据填充到布局.响应用户操作 2.ListView的实现需要:布局.数据源.适配器 3.常见适配器: ArrayAdapter<T>  用来绑定一 ...

  9. js 日期

    let date = new Date(); let year = date.getFullYear(); let money = money = date.getMonth() + 1; let d ...

  10. NLP用CNN分类Mnist,提取出来的特征训练SVM及Keras的使用(demo)

    用CNN分类Mnist http://www.bubuko.com/infodetail-777299.html /DeepLearning Tutorials/keras_usage 提取出来的特征 ...