java web 项目中 简单定时器实现 Timer
2016-01-14 17:28
375 查看
javaweb项目中简单定时器实现Timer
项目背景:系统中有一个存放压缩文件的临时文件夹。当时间长了后存放文件多了,占用磁盘空间过大让费资源,所以需要定期去清理临时文件夹下的文件。所以最先想到了使用定时器来实现该功能。
调查:通过查阅资料了解到使用java实现这个功能有三种方法
1》使用Quartz框架这是一个开源的任务调度框架
2》使用ScheduledExecutor实现
3》使用timer实现
因为我这只是要实现一个简单定时清理临时文件夹的任务不需要太多复杂的东西。所以我选择了第三种方案自己使用jdk自带的timer类来实现。
任务类主要的业务代码
这个类主要是继承TimerTask并实现它的run方法
下面就是监听类了监听服务器的启动并将任务添加到任务栈
任务类监听器类都实现了下一步就是在web.xml配置监听器了
到了这里一个简单的定时器基本上实现了也能跑通了接下来需要做的就是根据自己项目的实际要求去丰富定时器类DelFileTask和启动定时器的ContextListener。
schedule(TimerTasktask,longdelay)安排在指定延迟后执行指定的任务。(只执行一次)
参数:
[/code]
参数:
[/code]
安排指定的任务从指定的延迟后开始进行重复的固定延迟执行。以近似固定的时间间隔(由指定的周期分隔)进行后续执行。
在固定延迟执行中,根据前一次执行的实际执行时间来安排每次执行。如果由于任何原因(如垃圾回收或其他后台活动)而延迟了某次执行,则后续执行也将被延迟。从长期来看,执行的频率一般要稍慢于指定周期的倒数(假定Object.wait(long)所依靠的系统时钟是准确的)。
固定延迟执行适用于那些需要“平稳”运行的重复活动。换句话说,它适用于在短期运行中保持频率准确要比在长期运行中更为重要的活动。这包括大多数动画任务,如以固定时间间隔闪烁的光标。这还包括为响应人类活动所执行的固定活动,如在按住键时自动重复输入字符。
参数:
delay+System.currentTimeMillis()是负数。
安排指定的任务在指定的时间开始进行重复的固定延迟执行。以近似固定的时间间隔(由指定的周期分隔)进行后续执行。
在固定延迟执行中,根据前一次执行的实际执行时间来安排每次执行。如果由于任何原因(如垃圾回收或其他后台活动)而延迟了某次执行,则后续执行也将被延迟。在长期运行中,执行的频率一般要稍慢于指定周期的倒数(假定Object.wait(long)所依靠的系统时钟是准确的)。
固定延迟执行适用于那些需要“平稳”运行的重复执行活动。换句话说,它适用于在短期运行中保持频率准确要比在长期运行中更为重要的活动。这包括大多数动画任务,如以固定时间间隔闪烁的光标。这还包括为响应人类活动所执行的固定活动,如在按住键时自动重复输入字符。
参数:
参考文章:http://blog.csdn.net/xiaojin21cen/article/details/7725565
项目背景:系统中有一个存放压缩文件的临时文件夹。当时间长了后存放文件多了,占用磁盘空间过大让费资源,所以需要定期去清理临时文件夹下的文件。所以最先想到了使用定时器来实现该功能。
调查:通过查阅资料了解到使用java实现这个功能有三种方法
1》使用Quartz框架这是一个开源的任务调度框架
2》使用ScheduledExecutor实现
3》使用timer实现
因为我这只是要实现一个简单定时清理临时文件夹的任务不需要太多复杂的东西。所以我选择了第三种方案自己使用jdk自带的timer类来实现。
任务类主要的业务代码
packagecom.sxl; importjava.util.TimerTask; importjavax.servlet.ServletContext; /** *定时器 *@authorsxl * */ publicclassDelFileTaskextendsTimerTask{ privatestaticbooleanisRunning=false; privateServletContextcontext=null; publicDelFileTask(){ super(); } publicDelFileTask(ServletContextcontext){ this.context=context; } @Override publicvoidrun(){ if(!isRunning){ context.log("开始执行指定任务"); /** *自己的业务代码 */ isRunning=false; context.log("指定任务执行结束"); }else{ context.log("上一次任务执行还未结束"); } } }
这个类主要是继承TimerTask并实现它的run方法
下面就是监听类了监听服务器的启动并将任务添加到任务栈
packagecom.sxl; importjava.util.Calendar; importjava.util.Date; importjavax.servlet.ServletContextEvent; importjavax.servlet.ServletContextListener; publicclassContextListenerimplementsServletContextListener{ publicContextListener(){ } privatejava.util.Timertimer=null; /** *初始化定时器 *web程序运行时候自动加载 */ @Override publicvoidcontextInitialized(ServletContextEventarg0){ /** *设置一个定时器 */ timer=newjava.util.Timer(true); arg0.getServletContext().log("定时器已启动"); /** *定时器到指定的时间时,执行某个操作(如某个类,或方法) */ //设置执行时间 Calendarcalendar=Calendar.getInstance(); intyear=calendar.get(Calendar.YEAR); intmonth=calendar.get(Calendar.MONTH); intday=calendar.get(Calendar.DAY_OF_MONTH);//每天 //定制每天的1:00:00执行, calendar.set(year,month,day,01,00,00); Datedate=calendar.getTime(); //System.out.println(date); intperiod=24*60*60*1000; //每天的date时刻执行task,每隔persion时间重复执行 timer.schedule(newDelFileTask(arg0.getServletContext()),date,period); //在指定的date时刻执行task,仅执行一次 //timer.schedule(newDelFileTask(arg0.getServletContext()),date); arg0.getServletContext().log("已经添加任务调度表"); } /** *销毁 */ @Override publicvoidcontextDestroyed(ServletContextEventarg0){ timer.cancel(); arg0.getServletContext().log("定时器销毁"); } }这个类主要是设置一个调度器并让他按一定的要求去执行任务。
任务类监听器类都实现了下一步就是在web.xml配置监听器了
<listener> <listener-class>com.sxl.ContextListener</listener-class> </listener>
到了这里一个简单的定时器基本上实现了也能跑通了接下来需要做的就是根据自己项目的实际要求去丰富定时器类DelFileTask和启动定时器的ContextListener。
java.util.Timer类的schedule方法说明
参数:
task-所要安排的任务。
delay-执行任务前的延迟时间,单位是毫秒。抛出:
IllegalArgumentException-如果delay是负数,或者delay+System.currentTimeMillis()是负数。
IllegalStateException-如果已经安排或取消了任务,或者已经取消计时器。
[/code]
schedule(TimerTasktask,Datetime)安排在指定的时间执行指定的任务。如果此时间已过去,则安排立即执行该任务。(只执行一次)
参数:
task-所要安排的任务。
time-执行任务的时间。抛出:
IllegalArgumentException-如果time.getTime()是负数。
IllegalStateException-如果已经安排或取消了任务,已经取消了计时器,或者计时器线程已终止。
[/code]
schedule(TimerTasktask,longdelay,longperiod)
安排指定的任务从指定的延迟后开始进行重复的固定延迟执行。以近似固定的时间间隔(由指定的周期分隔)进行后续执行。
在固定延迟执行中,根据前一次执行的实际执行时间来安排每次执行。如果由于任何原因(如垃圾回收或其他后台活动)而延迟了某次执行,则后续执行也将被延迟。从长期来看,执行的频率一般要稍慢于指定周期的倒数(假定Object.wait(long)所依靠的系统时钟是准确的)。
固定延迟执行适用于那些需要“平稳”运行的重复活动。换句话说,它适用于在短期运行中保持频率准确要比在长期运行中更为重要的活动。这包括大多数动画任务,如以固定时间间隔闪烁的光标。这还包括为响应人类活动所执行的固定活动,如在按住键时自动重复输入字符。
参数:
task-所要安排的任务。
delay-执行任务前的延迟时间,单位是毫秒。
period-执行各后续任务之间的时间间隔,单位是毫秒。抛出:
IllegalArgumentException-如果delay是负数,或者
delay+System.currentTimeMillis()是负数。
IllegalStateException-如果已经安排或取消了任务,已经取消了计时器,或者计时器线程已终止。
schedule(TimerTasktask,DatefirstTime,longperiod)
安排指定的任务在指定的时间开始进行重复的固定延迟执行。以近似固定的时间间隔(由指定的周期分隔)进行后续执行。
在固定延迟执行中,根据前一次执行的实际执行时间来安排每次执行。如果由于任何原因(如垃圾回收或其他后台活动)而延迟了某次执行,则后续执行也将被延迟。在长期运行中,执行的频率一般要稍慢于指定周期的倒数(假定Object.wait(long)所依靠的系统时钟是准确的)。
固定延迟执行适用于那些需要“平稳”运行的重复执行活动。换句话说,它适用于在短期运行中保持频率准确要比在长期运行中更为重要的活动。这包括大多数动画任务,如以固定时间间隔闪烁的光标。这还包括为响应人类活动所执行的固定活动,如在按住键时自动重复输入字符。
参数:
task-所要安排的任务。
firstTime-首次执行任务的时间。
period-执行各后续任务之间的时间间隔,单位是毫秒。抛出:
IllegalArgumentException-如果time.getTime()是负数。
IllegalStateException-如果已经安排或取消了任务,已经取消了计时器,或者计时器线程已终止。
参考文章:http://blog.csdn.net/xiaojin21cen/article/details/7725565
相关文章推荐
- 【第十章】集成其它Web框架 之 10.3 集成Struts2.x ——跟我学spring3
- java中的 泛型类、泛型方法、泛型接口
- 《JAVA与模式》之模板方法模式
- @PathVariable-------springMVC
- spring初始化refresh()方法中obtainFreshBeanFactory()源码走读。
- NDK JNI 笔记
- java中“==”、equals和hashCode的区别
- Java 的数值是怎么存储的
- 【第十章】集成其它Web框架 之 10.2 集成Struts1.x ——跟我学spring3
- java 添加水印文字和图片
- Cannot use the diamond generic notation when running in JDK inferior to 1.7 mode
- Eclipse 保存文件时自动格式化代码
- java学习个人笔记---内存管理小技巧(编程序习惯)
- Java异常处理和设计
- JAVA实现邮箱验证
- JDK环境变量设置
- Eclipse中,修改文件的默认打开方式
- JAVA基础知识总结
- Spring mvc使用不了jstl
- 【第十章】集成其它Web框架 之 10.1 概述 ——跟我学spring3