一、什么是定时任务调度?

基于给定的时间点、给定的时间间隔或者给定的执行次数自动执行的任务。

1、常用的定时调度工具:Timer和Quartz

对时间的控制上,能实现简单的定时任务。

若特定时间的定时任务,需要用Quartz,它的定时机制更加庞大。

Quartz可以使用多个执行线程来实现。

二、Timer简介

1、Timer的定义以及架构

Timer定义:java.lang.object,是java.util.Timer包下。

一个后台的线程,后台线程支持多个目录定时执行。

有且仅有一个后台线程多个业务线程进行定时定频率的调度。

主要构件:

Timer——>定时调用——>TimerTask(业务线程)。

TimerThread后台执行的线程。

TimerTask对应的业务线程, TimerThread通过定期的调用TimerTask的run方法来实现定时调度。

2、Timer示例

import java.util.TimerTask;

public class MytimerTask extends TimerTask{
private String name;
//添加name的set和get方法
public MyTimerTask(String inputname){
name=inputname;
} @Override
public void run(){
//打印输出内容:
out.print("test"+name);
}
}
public class Mytimer{

    public static void main(String[] args){
//1:创建一个timer实例
Timer timer = new Timer();
//2:创建一个MyTimerTask实例
MyTimeTask myTimerTask = new MyTimerTask("No.1");
//3:通过timer定时定频率调用MyTimerTask的业务逻辑
//即第一次执行是在当前时间的两秒之后,之后每隔一秒钟执行一次
timer.schedule(myTimerTask,2000L,1000L);
}
}

三、Timer的定时调度函数

1、schedule的四种用法

①、chedule(task,time):参数:

  • task - 所要安排的任务
  • time - 执行任务的时间

作用:在时间等于或超过time的时候执行切仅执行一次task;

②、schedule(task,time,period):参数

  • task - 所要安排的任务
  • time - 执行任务的时间
  • period - 执行一次task的时间间隔,单位是毫秒

作用:时间等于或超过time时首次执行task,之后每隔period毫秒重复执行一次task。

③、schedule(task,delay):参数

  • task - 所要安排的任务
  • delay - 执行任务前的延迟时间,单位是毫秒

作用:等待delay毫秒后执行且仅执行一次task。

④、 schedule(task,delay,period):参数

  • task - 所要安排的任务
  • delay - 执行任务前的延迟时间,单位是毫秒
  • period - 执行一次task的时间间隔,单位是毫秒

作用:等待delay毫秒后首次执行task,之后每隔period毫秒重复执行一次task。

import java.util.TimerTask;

public class MytimerTask extends TimerTask{
private String name;
//添加name的set和get方法
public MyTimerTask(String inputname){
name=inputname;
} @Override
public void run(){
//以yyyy-MM-dd HH:mm:ss的格式打印当前执行时间
Calendar calendar = Calendar.getInstance();
SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
//打印当前执行时间
out.print("当前时间:"+sf.format(calendar.getTime())); //打印name:
out.print("test"+name);
}
}
public class Mytimer{

    public static void main(String[] args){
//1:创建一个timer实例
Timer timer = new Timer();
//2:创建一个MyTimerTask实例
MyTimeTask myTimerTask = new MyTimerTask("No.1");
//3:通过timer定时定频率调用MyTimerTask的业务逻辑
//即第一次执行是在当前时间的两秒之后,之后每隔一秒钟执行一次
//timer.schedule(myTimerTask,2000L,1000L); Calendar calendar = Calendar.getInstance();
SimpleDateFormat sf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
//打印当前执行时间
out.print("当前时间:"+sf.format(calendar.getTime()));
//设置3秒之后的时间
calendar.add(Calendar.SECOND,3); //schedule的用法
/**
* 1、在时间等于或超过time的时候执行且仅执行一次task
/ myTimerTask.setName("schedule1");
timer.schedule(myTimerTask,calendar.getTime()); /**
*2、时间等于或超过time时首次执行task
*之后每隔period毫秒重复执行一次task
/
myTimerTask.setName("schedule2");
//每隔2秒钟,重复执行myTimerTask方法中的run方法
timer.schedule(myTimerTask,calendar.getTime(),2000);
} /**
*3、等待delay毫秒后执行且仅执行一次task
*如现在是00:00:00
*则在00:00:01执行一次task,打印任务的名字
/
myTimerTask.setName("schedule3");
timer.schedule(myTimerTask,1000); /**
*4、等待delay毫秒后首次执行task,之后每隔period毫秒重复执行一次task
/
myTimerTask.setName("schedule4");
timer.schedule(myTimerTask,3000,2000); }

2、scheduleAtFixedRate的两种用法

scheduleAtFixedRate(task,time,period) :参数

- task - 所要安排的任务

- time- 首次执行任务的时间

- period - 执行一次task的时间间隔,单位是毫秒

作用:时间等于或超过time时首次执行task,之后每隔period毫秒重复执行一次task。

scheduleAtFixedRate(task,delay,period) :参数

- task - 所要安排的任务

- delay- 执行任务前的延迟时间,单位是毫秒

- period - 执行一次task的时间间隔,单位是毫秒

作用:时间等于或超过time时首次执行task,之后每隔period毫秒重复执行一次task。

    /**
*1、时间等于或超过timer时首次执行task,之后每隔period毫秒重复执行一次task
/
myTimerTask.setName("scheduleAtFixedRate1");
timer.scheduleAtFixedRate(myTimerTask,calendar.getTime(),2000); /**
*2、等待delay毫秒后首次执行task,之后每隔period毫秒重复执行一次task
/
myTimerTask.setName("scheduleAtFixedRate2");
timer.scheduleAtFixedRate(myTimerTask,3000,2000);

四、其他重要函数

1、TimerTask的cancel(),scheduleExecutionTime()

cancel():

作用:取消当前TimerTask里的任务

//计时器
private Integer count=0; void run(){
if(count < 3){
//业务 count++;
}else{
//任务取消
cancel();
}
}

scheduleExecutionTime():

作用:返回此任务最近实际执行的已安排执行的时间

返回值:最近发生此任务执行安排的时间,为long型。

    myTimerTask.setName("schedule");
timer.scheduleAtFixedRate(myTimerTask,3000);
out.print("test":sf.format(myTimerTask.scheduleExecutionTime()));

2、Timer的cancel(),purge()

cancel()

作用:终止此计时器,丢弃所有当前已安排的任务。

    //休眠5秒
Thread.sleep(5000);
//取消当前所有任务
timer.calcel();

purge():

作用:从此计时器的任务队列中移除所有已取消的任务。

返回值:从队列中移除的任务数。

    timer.schedule(task2,1000,2000);
timer.purge(); Thread.sleep(2000);
Date cancelTimer = new Date();
task2.cancel();

五、schedule与schduleAtFixedRate的区别

1、区别:首次计划执行的时间早于当前的时间

schdule:

“fixed-delay”:如果第一次执行时间被delay了,随后的执行时间按照上一次实际执行完成的时间点进行计算。

void main(String[] args){
//规定时间格式
final SimpleDateFormat sf = new SimpleDateFormat(yy:MM:dd mm:HH:ss)
//获取当前时间
Calendar calendar = Caledndar.getInstance();
out.print("sf.format(calendar.getTime()));
//设置成6秒前的时间,若当前时间为 00:00:06,
//那么设置之后时间变成00:00:00
calendar.add(Calendar.SECOND,-6);
Timer timer = new Timer();
//第一次执行时间为6秒前,之后每隔2秒钟执行一次
timer.schedule(new TimerTask(){
public void run(){
//打印当前的计划执行时间
out.print("test:"+sf.format(scheduleExecutionTimer()));
}
},calendar.getTimer(),2000);
}

schduleAtFixedRate方法:

“fixed-rate”:如果第一次执行时间被delay了,随后的执行时间按照上一次开始的时间点进行计算,并且为了赶上进度会多次执行任务,因此TimerTask中的执行体需要考虑同步

    timer.schduleAtFixedRate(new TimerTask(){
public void run(){
//打印当前的计划执行时间
out.print("test:"+sf.format(scheduleExecutionTimer()));
}
},calendar.getTimer(),2000);

2、区别:任务执行所需时间超过任务的执行周期间隔

schdule方法:

下一次执行时间相对于上一次实际执行完成的时间点,因此执行时间会不断延后

void main(String[] args){
//规定时间格式
final SimpleDateFormat sf = new SimpleDateFormat(yy:MM:dd mm:HH:ss)
//获取当前时间
Calendar calendar = Caledndar.getInstance();
out.print("sf.format(calendar.getTime()));
Timer timer = new Timer();
//第一次执行时间为6秒前,之后每隔2秒钟执行一次
timer.schedule(new TimerTask(){
public void run(){
try{
Thread.sleep(3000);
}catch (InterruptedException e){
e.printStackTrace();
}
//打印当前的计划执行时间
out.print("test:"+sf.format(scheduleExecutionTimer()));
}
},calendar.getTimer(),2000);
}

schduleAtFixedRate方法:

下一次执行时间相对于上一次开始的时间点,因此执行时间一般不会延后,因此存在并发性

timer.schduleAtFixedRate(new TimerTask(){
public void run(){
try{
Thread.sleep(3000);
}catch (InterruptedException e){
e.printStackTrace();
}
//打印当前的计划执行时间
out.print("test:"+sf.format(scheduleExecutionTimer()));
}
},calendar.getTimer(),2000);

六、Timer的缺陷

1、管理并发任务的缺陷

Timer有且仅有一个后台的线程,并不支持任务与任务之间的并发;如果存在多个任务,且任务时间过长,会导致执行效果与预期不符;

第二个任务会在第一个任务执行完成后在执行自己的任务;

2、当任务抛出异常时的缺陷

如果 TimerTask抛出RuntimeException,Timer会停止所有任务的运行;

    throw new RuntiomeException();  

第一个任务如果抛出异常,则第二个任务就不会再继续执行了,直接从第一个任务开始终止执行;

3、Timer的使用禁区:

对时效性要求较高的多任务并发作业:

对复杂任务的调度;

Java——定时任务调度工具的更多相关文章

  1. java定时任务调度工具

    一.什么是定时任务调度 基于给定的时间点,给定的时间间隔或者给定的时间执行次数自动执行的任务. 二.java中常用的定时任务调度工具: Timer Quartz 2.1两者区别: Timer源自jdk ...

  2. Java定时任务调度工具Timer Quartz

      -----------------------------------Timer PS:Timer是 jdk中的:Quartz是第三方的 PS:也即是返回执行任务时候的时间 ----------- ...

  3. java定时任务调度工具Timer与Quartz的区别

    Timer与Quartz的区别有三点: 1.出身不同:Timer由jdk直接提供,调用方式简单粗暴,不需要其它jar包支持.Quartz并非jdk自带,需要引入相应的jar包 2.能力区别:主要体现在 ...

  4. Java学习笔记 -- Java定时调度工具Timer类

    1 关于 (时间宝贵的小姐姐请跳过) 本教程是基于Java定时任务调度工具详解之Timer篇的学习笔记. 什么是定时任务调度 基于给定的时间点,给定的时间间隔或者给定的执行次数自动执行的任务. 在Ja ...

  5. Java定时任务调度详解

    前言 在实际项目开发中,除了Web应用.SOA服务外,还有一类不可缺少的,那就是定时任务调度.定时任务的场景可以说非常广泛,比如某些视频网站,购买会员后,每天会给会员送成长值,每月会给会员送一些电影券 ...

  6. JAVA定时任务调度之Timer入门详解(一)

    所谓的Timer,打开jdk的api文档可以看到它的定义:一种工具,线程用其安排以后在后台线程中执行的任务.可安排任务执行一次,或者定期重复执行.通俗点讲就是说:有且仅有一个后台线程对多个业务线程进行 ...

  7. java定时任务调度框架

    java定时任务目前主要有三种: Java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务.使用这种方式可以让你的程序按照某一个频度执行,但不能在 ...

  8. java定时任务调度-Timer(1)

    一.定义 有且仅有一个后台线程对多个业务线程进行定时定频率的调度 二. Timer  ---->  Timer Task  (中有run();方法) 通过 new Timer().schedul ...

  9. #研发中间件介绍#定时任务调度与管理JobCenter

    郑昀 最后更新于2014/11/11 关键词:定时任务.调度.监控报警.Job.crontab.Java 本文档适用人员:研发员工   没有JobCenter时我们要面对的:   电商业务链条很长,业 ...

随机推荐

  1. chrome实现网页高清截屏(F12、shift+ctrl+p、capture)

    打开需要载屏的网页,在键盘上按下F12,出现以下界面 上图圈出的部分有可能会出现在浏览器下方,这并没有关系.此时按下 Ctrl + Shift + P(Mac 为 ⌘Command +⇧Shift + ...

  2. OpenResty 简介

    OpenResty 简介 OpenResty 是一个基于 Nginx 与 Lua 的高性能 Web 平台.我们知道开发 Nginx 的模块需要用 C 语言,同时还要熟悉它的源码,成本和门槛比较高.国人 ...

  3. HDFS 修改默认副本数

    描述:将HDFS副本数修改为2第一步:将HDFS上已有文件副本数修改为2 hdfs dfs -setrep 2 -R -w / 第二步:修改dfs.replication值为2(页面上操作),然后重启 ...

  4. 风炫安全web安全学习第三十节课 命令执行&代码执行基础

    风炫安全web安全学习第三十节课 命令执行&代码执行基础 代码执行&命令执行 RCE漏洞,可以让攻击者直接向后台服务器远程注入操作系统命令或者代码,从而控制后台系统. 远程系统命令执行 ...

  5. Lesson_strange_words2

    cap 大写字母 mechanical 机械的,力学的 optical 光学的,视觉的 charge 电荷,负载 couple 耦合的,联接的,成对的 charge-coupled device 电荷 ...

  6. Java并发编程实战(5)- 线程生命周期

    在这篇文章中,我们来聊一下线程的生命周期. 目录 概述 操作系统中的线程生命周期 Java中的线程生命周期 Java线程状态转换 运行状态和阻塞状态之间的转换 运行状态和无时限等待状态的切换 运行状态 ...

  7. MongoDB备份(mongodump)与恢复(mongorestore)工具实践

    mongodump和mongorestore实践 1.mongodump备份工具 mongodump能够在Mongodb运行时进行备份,它的工作原理是对运行的Mongodb做查询,然后将所有查到的文档 ...

  8. drop table 命令不回收以前的相关访问权限

    drop table 命令不回收以前的相关访问权限,也就是说假如我现在把表删除了,然后再创建一个同名的表时,会自动赋予权限的.

  9. 【System】paging和swaping之间的区别是什么?

    分析paging和swapping的区别,首先要了解内存管理 当虚拟内存用二级存储(物理磁盘)作为主存的扩展时,内核会尽力保持最活跃的数据在主存中.有一下两个内核例程做这件事情: 1.交换(swapp ...

  10. 如何构建一个多人(.io) Web 游戏,第 2 部分

    原文:How to Build a Multiplayer (.io) Web Game, Part 2 探索 .io 游戏背后的后端服务器. 上篇:如何构建一个多人(.io) Web 游戏,第 1 ...