热门标签 | HotTags
当前位置:  开发笔记 > 前端 > 正文

java定时器timer的使用方法代码示例

这篇文章主要介绍了java定时器timer的使用方法代码示例,向大家分享了两部分代码,详细内容请参见正文,还是比较不错的,需要的朋友可以参考下。

 1.首先肯定是容器一启动就要启动定时器,所以我们可以选择把定时器写在一个监听器里,容器一启动所以监听器也就跟着启动,然后定时器就可以工作了。

第一步,把自己写的监听器加到web.xml中;
第二步,写一个监听器,实现ServletContextListener接口;
第三步,写一个定时器,继承TimerTask,在复写的run()方法里写具体的业务逻辑。
第四步,在自己的监听器里复写的

public void contextInitialized(ServletContextEvent arg0){
}

这个方法里调用定时器的schedule方法。

具体代码如下:

web.xml添加:



  com.dcits.app.servlet.MyTimerTaskListener

MyTimerTaskListener.java

package com.dcits.app.servlet;
import java.util.Calendar;
import java.util.Timer;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;
/**
 * @author Weiyongle
 * @time 2017-5-5 下午2:05:32
 */
public class MyTimerTaskListener implements ServletContextListener {
	private Timer timer = null;
	@Override
	  public void contextDestroyed(ServletContextEvent arg0) {
		timer.cancel();
	}
	@Override
	  public void contextInitialized(ServletContextEvent arg0) {
		System.out.println("-----开始启动定时器------");
		Calendar twentyOne= Calendar.getInstance();
		twentyOne.set(Calendar.HOUR_OF_DAY, 23);
		twentyOne.set(Calendar.MINUTE, 0);
		twentyOne.set(Calendar.SECOND, 0);
		timer = new Timer(true);
		//第一次是晚上23点执行,间隔24小时执行一次
		timer.schedule(new MyTimerTask(), twentyOne.getTime(), 1000*60*60*24);
		//*System.out.println("-----开始启动定时器------");
    Calendar twentyOne= Calendar.getInstance();
    twentyOne.set(Calendar.HOUR_OF_DAY, 14);
    twentyOne.set(Calendar.MINUTE, 47);
    twentyOne.set(Calendar.SECOND, 0);
    timer = new Timer(true);
    timer.schedule(new MyTimerTask(), twentyOne.getTime(), 1000*10);*/
	}
}

MyTimerTask.java

package com.dcits.app.servlet;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;
import java.util.TimerTask;
import org.codehaus.jackson.JsonGenerationException;
import org.codehaus.jackson.map.JsonMappingException;
/**
 * 定时器,用于补偿认证的时候没有获取到正常返回的那些数据
 * @author Weiyongle
 * @time 2017-5-5 下午2:20:12
 */
public class MyTimerTask extends TimerTask{
	private static StringBuffer url = new StringBuffer();
	@Override
	  public void run() {
		//生产环境
		//    url.append("https://我是具体的ip地址/nmsypt/servlet/webServlet");//生产环境
		url.append("http://localhost:8080/adp/servlet/webServlet");
		//本地环境
		Map reqMap = new HashMap();
		//这里的map从数据库里获取对应的数据不写死就行了,先获取map,在写个for循环进行循环就行了
		reqMap.put("QYMC","丹同学的公司");
		reqMap.put("NSRSBH","158028307441234");
		reqMap.put("SJHM_FR","15802830744");
		reqMap.put("YZM","123456");
		reqMap.put("CWFZR","");
		//
		reqMap.put("ZJLX_DM_CW","");
		//
		reqMap.put("ZJHM_CW","");
		//
		reqMap.put("ZGRS","1234");
		reqMap.put("SQYY","");
		//
		reqMap.put("JRCPBM","00002");
		reqMap.put("XYDM","1");
		reqMap.put("XZQHDM","");
		reqMap.put("QYBM","QY17900000647001");
		try {
			CompensateData.CompensateDatas(url.toString(), reqMap);
			System.out.println("-----成功补偿了一条认证信息------");
		}
		catch (JsonGenerationException e) {
			e.printStackTrace();
		}
		catch (JsonMappingException e) {
			e.printStackTrace();
		}
		catch (IOException e) {
			e.printStackTrace();
		}
	}
}

另外,有关于定时器还有事情要介绍,又是一个示例,哈哈,比较有意思的。

运行后,我们发现三秒后控制台打印出了相当的文字,但是任务虽然执行完了,进程却没有销毁,还是呈红色状态,这是什么原因呢?

创建了一个Timer就相当于启动了一个新线程,这个新线程并不是守护线程,所以会一直运行.

在Time类和TimerTask类中都有一个cancel()方法.

TimerTask类中的作用是:将自身从任务队列中清除,(一个Timer对象可以执行多个Timertask任务)

Timer类中的作用是:将任务队列中的全部任务清空.

下面写一个实例,定时删除指定磁盘某个目录下的所有文件:

package com.wang.reflect;
import java.io.File;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;
class MyTask extends TimerTask{
/**
 * 定时删除指定位置的文件,(这里以删除f盘下aa文件夹的所有文件为例)
 */
  @Override
  public void run() {
    File file=new File("f://aa");
    deleteFolder(file);
  }
  public void deleteFolder(File file){
    File[] files=file.listFiles();
    for(File f:files){
      if(f.isDirectory()){
        //使用递归
        deleteFolder(f);
      }else{
        f.delete();
      }
    }
    file.delete();
  }
}
public class TimerDemo {
  public static void main(String[] args) throws ParseException {
    //创建定时器对象
    Timer t=new Timer();
    String time="2016-04-04 11:26:40";
    Date d=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").parse(time);
    t.schedule(new MyTask(), d);
  }
}

注意,如果在上面测试代码中,我给出的Date类型的时间,早于当前的时间.则会立即执行task任务.

总结

以上就是本文关于java定时器timer的使用方法代码示例全部内容,希望对大家有所帮助。欢迎参阅:Map集合的四种遍历方式代码示例、Java中Switch用法代码示例、java加解密RSA使用方法代码示例等,有什么问题请留言指出,感谢大家。


推荐阅读
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
  • 本文介绍了如何利用 Spring Boot 和 Groovy 构建一个灵活且可扩展的动态计算引擎,以满足钱包应用中类似余额宝功能的推广需求。我们将探讨不同的设计方案,并最终选择最适合的技术栈来实现这一目标。 ... [详细]
  • SpringMVC RestTemplate的几种请求调用(转)
    SpringMVCRestTemplate的几种请求调用(转),Go语言社区,Golang程序员人脉社 ... [详细]
  • 本文详细介绍如何利用已搭建的LAMP(Linux、Apache、MySQL、PHP)环境,快速创建一个基于WordPress的内容管理系统(CMS)。WordPress是一款流行的开源博客平台,适用于个人或小型团队使用。 ... [详细]
  • 自 Node.js 6.3 版本起,调试功能已内置在核心模块中,无需额外安装 node-inspector 等工具。通过简单的命令即可启动调试模式,并利用 Chrome 浏览器进行高效的代码调试。 ... [详细]
  • 采用IKE方式建立IPsec安全隧道
    一、【组网和实验环境】按如上的接口ip先作配置,再作ipsec的相关配置,配置文本见文章最后本文实验采用的交换机是H3C模拟器,下载地址如 ... [详细]
  • 我有一个SpringRestController,它处理API调用的版本1。继承在SpringRestControllerpackagerest.v1;RestCon ... [详细]
  • 简化报表生成:EasyReport工具的全面解析
    本文详细介绍了EasyReport,一个易于使用的开源Web报表工具。该工具支持Hadoop、HBase及多种关系型数据库,能够将SQL查询结果转换为HTML表格,并提供Excel导出、图表显示和表头冻结等功能。 ... [详细]
  • 理解UML的重要性及其应用
    探讨为什么大多数开发人员难以成为架构师,介绍从现实世界到业务模型的抽象过程,并详细解释UML在软件设计中的关键作用。 ... [详细]
  • ABBYY FineReader:高效PDF转换、精准OCR识别与文档对比工具
    在处理PDF转换和OCR识别时,您是否遇到过格式混乱、识别率低或图表无法正常识别的问题?ABBYY FineReader以其强大的功能和高精度的识别技术,完美解决这些问题,帮助您轻松找到最终版文档。 ... [详细]
  • HTML基础入门指南
    本文将深入浅出地介绍HTML的基础知识,包括其定义、开发工具、制定机构、特性、基本标签及更多实用内容。 ... [详细]
  • 本文探讨了如何在Classic ASP中实现与PHP的hash_hmac('SHA256', $message, pack('H*', $secret))函数等效的哈希生成方法。通过分析不同实现方式及其产生的差异,提供了一种使用Microsoft .NET Framework的解决方案。 ... [详细]
  • Spring Boot 中静态资源映射详解
    本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
  • ArcXML:互联网空间数据交换的专用语言
    ArcXML是一种专为ArcIMS平台设计的数据交换协议,基于XML标准,用于在不同组件之间传输和描述地理空间数据。本文将详细介绍ArcXML的背景、用途及其与XML的关系。 ... [详细]
  • 本文详细介绍如何使用 Python 集成微信支付的三种主要方式:Native 支付、APP 支付和 JSAPI 支付。每种方式适用于不同的应用场景,如 PC 网站、移动端应用和公众号内支付等。 ... [详细]
author-avatar
串串香是的
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有