Java自带的java.util.Timer类,通过调度一个java.util.TimerTask任务。

这种方式可以让程序按照某一个频度执行,但不能指定时间运行。用的较少。任务的调用通过起的子线程进行执行。

java.util.Timer

java.util.TimerTask

一、调用方法:

(1)void java.util.Timer.schedule(TimerTask task, long delay):

  多长时间(毫秒)后执行任务

(2)void java.util.Timer.schedule(TimerTask task, Date time):

  设定某个时间执行任务

(3)void java.util.Timer.schedule(TimerTask task, long delay, long period):

  delay时间后开始执行任务,并每隔period时间调用任务一次。

(4)void java.util.Timer.schedule(TimerTask task, Date firstTime, long period):

  第一次在指定firstTime时间点执行任务,之后每隔period时间调用任务一次。

(5)void java.util.Timer.scheduleAtFixedRate(TimerTask task, long delay, long period):

  delay时间后开始执行任务,并每隔period时间调用任务一次。

(6)void java.util.Timer.scheduleAtFixedRate(TimerTask task, long delay, long period):

  第一次在指定firstTime时间点执行任务,之后每隔period时间调用任务一次。

void java.util.Timer.cancel():终止该Timer

boolean java.util.TimerTask.cancel():终止该TimerTask

可以为每个Timer指定多个TimerTask

虽然可通过void java.util.Timer.schedule(TimerTask task, Date firstTime, long period)方法完成。

“例如:每天上午10点执行一次”的业务,但该实现是基于进行一天(1000 * 60 * 60 * 24毫秒)进行延迟的机制实现的,并不是指定某个具体时间进行执行的。

对于该种需求,可通过Quartz来进行实现

二、方法名称schedule()和scheduleAtFixedRate()两者的区别

当需要根据period区间时间循环多次调用任务的时候,会存在两种不同的策略,两种方法提供了不同的策略。

调用方法(1)、(2)只是单次执行,不存在多次调用任务的情况,所以没有提供scheduleAtFixedRate方法的调用方式。

<1>schedule()方法更注重保持间隔时间的稳定:保障每隔period时间可调用一次 <2>scheduleAtFixedRate()方法更注重保持执行频率的稳定:保障多次调用的频率趋近于period时间,如果某一次调用时间大于period,下一次就会尽量小于period,以保障频率接近于period

三、示例

(1)

  1. /**
  2. * 第一种方法:设定多长时间(毫秒)后执行任务
  3. */
  4. public static void timer1() {
  5. final StopWatch watch = new StopWatch();
  6. watch.start();
  7. Timer timer = new Timer();
  8. /* void java.util.Timer.schedule(TimerTask task, long delay) */
  9. timer.schedule(new TimerTask() {
  10. public void run() {
  11. watch.stop();
  12. System.out.println("-------任务执行--------");
  13. System.out.println(watch.getTime());
  14. }
  15. }, 2000);// delay=2000毫秒 后执行该任务
  16. }

(2)

  1. /**
  2. * 第二种方法:设定某个时间执行任务
  3. */
  4. public static void timer2() {
  5. Calendar calendar = new GregorianCalendar();
  6. calendar.add(Calendar.MINUTE, 1);
  7. calendar.set(Calendar.SECOND, 0); // 一分钟后执行
  8. Timer timer = new Timer();
  9. /* void java.util.Timer.schedule(TimerTask task, Date time) */
  10. timer.schedule(new TimerTask() {
  11. @Override
  12. public void run() {
  13. System.out.println("-------任务执行--------");
  14. }
  15. }, calendar.getTime());
  16. }

(3)

  1. /**
  2. * 第三种方法:设定指定任务task在指定延迟delay后进行固定延迟peroid的执行
  3. */
  4. public static void timer3() {
  5. Timer timer = new Timer();
  6. final StopWatch watch = new StopWatch();
  7. watch.start();
  8. System.out.println(Thread.currentThread().getName());
  9. /*
  10. * void java.util.Timer.schedule(TimerTask task, long delay, long
  11. * period)
  12. */
  13. timer.schedule(new TimerTask() {
  14. public void run() {
  15. /* 子线程进行任务的执行 */
  16. System.out.println(Thread.currentThread().getName());
  17. System.out.println("-------设定要指定任务--------");
  18. watch.suspend();
  19. System.out.println(watch.getTime());
  20. watch.reset();
  21. watch.start();
  22. }
  23. }, 1000, 1000);
  24. }

(4)

  1. /**
  2. * 固定延迟peroid时间后执行;peroid时间不是以任务执行完的时间为计算起点(某次任务执行完成后,经过peroid时间后再次调用[不是这样的])。
  3. * 而是每隔peroid时间调用任务一次。当任务执行的时间小于peroid时间,可以保证每隔peroid时间调用一次。
  4. * 当任务的执行时间大于peroid时间时,从现象上看:任务一执行完,就会立刻进入下一次任务的执行
  5. */
  6. public static void timer3a() {
  7. Timer timer = new Timer();
  8. final StopWatch watch = new StopWatch();
  9. watch.start();
  10. timer.schedule(new TimerTask() {
  11. Integer i = 1;
  12. public void run() {
  13. System.out.println(watch.getTime());
  14. System.out.println("########第" + i + "次执行开始########");
  15. try {
  16. Thread.sleep(400);
  17. } catch (InterruptedException e) {
  18. e.printStackTrace();
  19. }
  20. System.out.println("########第" + i + "次执行结束########");
  21. i++;
  22. watch.reset();
  23. watch.start();
  24. }
  25. }, 1000, 500);
  26. }

period:500毫秒;每次任务执行时间400毫秒;所以每次任务执行完成后到下一次任务调用开始的时间趋近于100毫秒

打印日志信息:

[plain] view plaincopy

  1. 1000
  2. ########第1次执行开始########
  3. ########第1次执行结束########
  4. 109
  5. ########第2次执行开始########
  6. ########第2次执行结束########
  7. 93
  8. ########第3次执行开始########
  9. ########第3次执行结束########
  10. 93
  11. ########第4次执行开始########
  12. ########第4次执行结束########
  13. 93
  14. ########第5次执行开始########
  15. ########第5次执行结束########
  16. 93
  17. ########第6次执行开始########
  18. ########第6次执行结束########
  19. 93
  20. ########第7次执行开始########
  21. ########第7次执行结束########
  22. 93
  23. ########第8次执行开始########

当将Thread.sleep(400);修改为Thread.sleep(600)时:

打印日志信息:

  1. 1000
  2. ########第1次执行开始########
  3. ########第1次执行结束########
  4. 0
  5. ########第2次执行开始########
  6. ########第2次执行结束########
  7. 0
  8. ########第3次执行开始########
  9. ########第3次执行结束########
  10. 0
  11. ########第4次执行开始########
  12. ########第4次执行结束########
  13. 0
  14. ########第5次执行开始########

(5)

  1. /**
  2. * 第四种方法:安排指定的任务task在指定的时间firstTime开始进行重复的固定速率period执行
  3. * 每天中午12点都执行一次
  4. */
  5. public static void timer4() {
  6. Calendar calendar = Calendar.getInstance();
  7. calendar.set(Calendar.HOUR_OF_DAY, 12); // 控制时
  8. calendar.set(Calendar.MINUTE, 0); // 控制分
  9. calendar.set(Calendar.SECOND, 0); // 控制秒
  10. Date time = calendar.getTime(); // 得出执行任务的时间,此处为今天的12:00:00
  11. Timer timer = new Timer();
  12. /* void java.util.Timer.schedule(TimerTask task, Date firstTime, long period) */
  13. timer.schedule(new TimerTask() {
  14. public void run() {
  15. System.out.println("-------设定要指定任务--------");
  16. }
  17. }, time, 1000 * 60 * 60 * 24);// 这里设定将延时每天固定执行
  18. }

(6)

    1. /**
    2. * 第五种方法:设定指定任务task在指定延迟delay后进行固定频率peroid的执行。
    3. * timer.schedule和timer.scheduleAtFixedRate的区别:
    4. * (1)schedule()方法更注重保持间隔时间的稳定:保障每隔period时间可调用一次
    5. * (2)scheduleAtFixedRate()方法更注重保持执行频率的稳定:保障多次调用的频率趋近于period时间,如果某一次调用时间大于period,下一次就会尽量小于period,以保障频率接近于period
    6. */
    7. public static void timer5() {
    8. Timer timer = new Timer();
    9. /* void java.util.Timer.scheduleAtFixedRate(TimerTask task, long delay, long period) */
    10. timer.scheduleAtFixedRate(new TimerTask() {
    11. public void run() {
    12. System.out.println("-------设定要指定任务--------");
    13. }
    14. }, 1000, 500);
    15. }

Java Timer及TimerTarsk(摘自网络)的更多相关文章

  1. java并发多线程(摘自网络)

    1. 进程和线程之间有什么不同? 一个进程是一个独立(self contained)的运行环境,它可以被看作一个程序或者一个应用.而线程是在进程中执行的一个任务.Java运行环境是一个包含了不同的类和 ...

  2. Java Timer

    Java Timer 定时类,主要用来执行定时任务 Timer管理所有要执行的定时任务 TimerTask封装好的定时任务 常见的用法 MyTask myTask = new MyTask(); Ti ...

  3. Android:控件WebView显示网页 -摘自网络

    WebView可以使得网页轻松的内嵌到app里,还可以直接跟js相互调用. webview有两个方法:setWebChromeClient 和 setWebClient setWebClient:主要 ...

  4. Java Timer触发定时器

    XML: <!-- Java Timer定时 --> <!-- <bean id="shortUrlTask" class=" com.sprin ...

  5. Java:利用java Timer类实现定时执行任务的功能

    一.概述 在java中实现定时执行任务的功能,主要用到两个类,Timer和TimerTask类.其中Timer是用来在一个后台线程按指定的计划来执行指定的任务.TimerTask一个抽象类,它的子类代 ...

  6. C# 中的内存管理,摘自网络

    C#编程的一个优点是程序员不需要关心具体的内存管理,尤其是垃圾收集器会处理所有的内存清理工作.虽然不必手工管理内存,但如果要编写高质量的代码,还是要理解后台发生的事情,理解C#的内存管理.本文主要介绍 ...

  7. JAVA Timer定时器使用方法(二)

    JAVA  Timer 定时器测试 MyTask.java:package com.timer; import java.text.SimpleDateFormat;import java.util. ...

  8. 20155324 《Java程序设计》实验五 网络编程与安全

    20155324 <Java程序设计>实验五 网络编程与安全 实验内容 任务一 编写MyBC.java实现中缀表达式转后缀表达式的功能 编写MyDC.java实现从上面功能中获取的表达式中 ...

  9. Ubuntu的常用快捷键(摘自网络)

    篇一 : Ubuntu的复制粘贴操作及常用快捷键(摘自网络) Ubuntu的复制粘贴操作 1.最为简单,最为常用的应该是鼠标右键操作了,可以选中文件,字符等,右键鼠标,复制,到目的地右键鼠标,粘贴就结 ...

随机推荐

  1. SQL语句获取数据库中的表主键,自增列,所有列

    SQL语句获取数据库中的表主键,自增列,所有列   获取表主键 1:SELECT TABLE_NAME,COLUMN_NAME FROM INFORMATION_SCHEMA.KEY_COLUMN_U ...

  2. php常量作用

    PHP常量的特点是: 1.不能通过外部来传递,也就是不能通过get与post还有cookie等方式来传递赋值,所以可以确定是程序执行过程中定义的,非外界变量.2.定义后不能更改,可以防止被篡改. 基于 ...

  3. 浏览器的云加速可能导致IP统计异常

    前段时间弄个流量统计相关的东西,请求展示图片时根据请求的IP进行 md5 签名生成点击链接的验证参数,结果发现一个莫名其妙的问题 发现点击日志中有一小部分点击的IP居然不一致,如果是开放给别人用可能存 ...

  4. android应用编译失败 ResXMLTree_node size 类错误,以及 android studio 项目内搜索

    今天很郁闷,又遇到个很让人崩溃的问题: ResXMLTree_node size 0 is smaller than header size 0x45. 类似这样的错误,提示中看不出任何有用的内容,网 ...

  5. 更改系统相机UIImagePickerController导航栏的cancle为自定义按钮

    有时候需要对系统相册里面的取消按钮进行自定义,并获取点击事件做一些操作,那么你可以这样做. 第一:实现navigationController代理 - (void)navigationControll ...

  6. android移动开发学习笔记(二)神奇的Web API

    本次分两个大方向去讲解Web Api,1.如何实现Web Api?2.如何Android端如何调用Web Api?对于Web Api是什么?有什么优缺点?为什么用WebApi而不用Webservice ...

  7. something funny

    something funny. #include <stdio.h> #include <windows.h> #define N 50 HANDLE hConsole; v ...

  8. 学习node的REPL

    REPL: read eval print loop 支持 多行代码 编辑模式,即 识别{} () 为代码块. 在repl中快速查看 对象的属性 gl = global repl command .h ...

  9. Qt对xml文件的读写

    最近研究了一下qt下对xml文件的读写,小计一下,成为自己的知识. main函数调用: #include <QApplication> #include "readconfig. ...

  10. 用angular实现$.param()

    首先介绍一下$.param() 功能: 序列化对象或数组,返回字符串 eg: var params = { width:1900, height:1200 }; var str = jQuery.pa ...