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

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

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

public void contextInitialized(ServletContextEvent arg0){
}

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

具体代码如下:

web.xml添加:

<!-- 用于补偿认证信息异常的数据,用来启动定时器,20170505 -->
<listener>
  <listener-class>com.dcits.app.servlet.MyTimerTaskListener</listener-class>
</listener>

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<String,Object> reqMap = new HashMap<String,Object>();
		//这里的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使用方法代码示例等,有什么问题请留言指出,感谢大家。

(0)

相关推荐

  • java使用TimerTask定时器获取指定网络数据

    复制代码 代码如下: import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.net.URL;import java.text.SimpleDateFormat;import java.util.Date;import java.util.Timer;import java.util.TimerTask; public class GetYinInf

  • Java 定时器(Timer,TimerTask)详解及实例代码

     Java 定时器 在JAVA中实现定时器功能要用的二个类是Timer,TimerTask Timer类是用来执行任务的类,它接受一个TimerTask做参数 Timer有两种执行任务的模式,最常用的是schedule,它可以以两种方式执行任务:1:在某个时间(Data),2:在某个固定的时间之后(int delay).这两种方式都可以指定任务执行的频率,本文有二个例子,一个是简单的一个是用了内部类 1.简单实例 先写一个类 public class TimeTest { public stat

  • Java 定时器(Timer)及线程池里使用定时器实例代码

    java Timer定时器 简单实例代码: public class Test { public static void main(String[] args) { // Timer定时器 Timer mTimer = new Timer(); MyTack myTack = new MyTack(); mTimer.schedule(myTack, 2000, 3000);//第一个参数是需要执行的任务 第二个参数是延迟多少时间最开始执行,第三个参数是执行完后多少时间后进行再次执行是一个周期性

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

    1.首先肯定是容器一启动就要启动定时器,所以我们可以选择把定时器写在一个监听器里,容器一启动所以监听器也就跟着启动,然后定时器就可以工作了. 第一步,把自己写的监听器加到web.xml中: 第二步,写一个监听器,实现ServletContextListener接口: 第三步,写一个定时器,继承TimerTask,在复写的run()方法里写具体的业务逻辑. 第四步,在自己的监听器里复写的 public void contextInitialized(ServletContextEvent arg0

  • java加解密RSA使用方法代码示例

    最近为了分析一段请求流,不得不去研究一下RSA加密. 首先,强调一点:密钥的"钥"读"yue",不是"yao",额... 网上关于RSA的原理一抓一大把的,这里只是简单说说我的理解: 1. 两个足够大的互质数p, q: 2. 用于模运算的模 n=p*q: 3. 公钥KU(e, n)中的e满足 1<e< (p-1)(q-1),且与(p-1)(q-1)互质: 4. 密钥KR(d, n)中的d满足  d*e % (p-1)(q-1)= 1,

  • Java压缩文件工具类ZipUtil使用方法代码示例

    本文实例通过Java的Zip输入输出流实现压缩和解压文件,前一部分代码实现获取文件路径,压缩文件名的更改等,具体如下: package com.utility.zip; import java.io.BufferedInputStream; import java.io.BufferedOutputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import

  • Java多线程执行处理业务时间太久解决方法代码示例

    背景:在政府开发了一个应用系统,主要功能是让企业填写企业资质信息,然后通过给定的公式,统计这一系列的信息,以得分的形式展示给政府领导查看.目前有1300家企业填报.由于得分是实时显示的,所以导致统计功能很慢. 代码运行流程: 1.查出1300企业信息 2.遍历1300企业信息,ji计算每家企业得分信息.每家预计时间为0.3秒.合计390秒.导致页面请求超时 3.导出(用jxl jar) 解决方案: 由于处理业务的,所以需要能有返回值的线程.用:Callable 直接上代码 1.调用线程的代码 L

  • Java KeyGenerator.generateKey的19个方法代码示例

    目录 示例1: EncryptByAes 示例2: main 示例3: wrapperPublicPriviteKeyTest 示例4: initHmacSHA224Key 示例5: run 示例6: initHmacSHA384Key 示例7: wrapperBlowfishKeyTest 示例8: generateMacSha1Key 示例9: ReadWriteSkip 示例10: generateKey 示例11: generateEncryptionSecret​ 示例12: init

  • Java多线程中断机制三种方法及示例

    概述 之前讲解Thread类中方法的时候,interrupt().interrupted().isInterrupted()三个方法没有讲得很清楚,只是提了一下.现在把这三个方法同一放到这里来讲,因为这三个方法都涉及到多线程的一个知识点----中断机制. Java没有提供一种安全.直接的方法来停止某个线程,而是提供了中断机制.中断机制是一种协作机制,也就是说通过中断并不能直接终止另一个线程,而需要被中断的线程自己处理.有个例子举个蛮好,就像父母叮嘱出门在外的子女要注意身体一样,父母说了,但是子女

  • SQL注入原理与解决方法代码示例

    一.什么是sql注入? 1.什么是sql注入呢? 所谓SQL注入,就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令,比如先前的很多影视网站泄露VIP会员密码大多就是通过WEB表单递交查询字符暴出的,这类表单特别容易受到SQL注入式攻击.当应用程序使用输入内容来构造动态sql语句以访问数据库时,会发生sql注入攻击.如果代码使用存储过程,而这些存储过程作为包含未筛选的用户输入的字符串来传递,也会发生sql注入. 黑客通过SQL注入攻击

  • Java编程redisson实现分布式锁代码示例

    最近由于工作很忙,很长时间没有更新博客了,今天为大家带来一篇有关Redisson实现分布式锁的文章,好了,不多说了,直接进入主题. 1. 可重入锁(Reentrant Lock) Redisson的分布式可重入锁RLock Java对象实现了java.util.concurrent.locks.Lock接口,同时还支持自动过期解锁. public void testReentrantLock(RedissonClient redisson){ RLock lock = redisson.getL

  • Spark的广播变量和累加器使用方法代码示例

    一.广播变量和累加器 通常情况下,当向Spark操作(如map,reduce)传递一个函数时,它会在一个远程集群节点上执行,它会使用函数中所有变量的副本.这些变量被复制到所有的机器上,远程机器上并没有被更新的变量会向驱动程序回传.在任务之间使用通用的,支持读写的共享变量是低效的.尽管如此,Spark提供了两种有限类型的共享变量,广播变量和累加器. 1.1 广播变量: 广播变量允许程序员将一个只读的变量缓存在每台机器上,而不用在任务之间传递变量.广播变量可被用于有效地给每个节点一个大输入数据集的副

  • Java 从互联网上爬邮箱代码示例

    网页爬虫:其实就是一个程序用于在互联网中获取符合指定规则的数据. package day05; import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.net.URL; import java.util.ArrayList; import java.util.List; import java.util.regex.Matcher; impor

随机推荐