定時器

轉自:http://apps.hi.baidu.com/share/detail/33720498java

1定時器的做用
在實際的開發中,若是項目中須要定時執行或者須要重複執行必定的工做,定時器顯現的尤其重要。
固然若是咱們不瞭解定時器就會用線程去實現,例如:
package org.lzstone.action
public class FinanceAction extends Thread{
       private Date date;
       public void run{
       try{
       while(true){
       Thread.sleep((int)(Math.random()*1000));
       date = new Date();
       //定時執行任務
       }
       }catch(Exception e){
        e.printStackTrace();
       }
}
}
本身實現定時器的工做很複雜,若是實現很差佔用內存過多,系統就此Over,因此處理定時執行或者重複執行的任務,定時器是很好的選擇
2.Java中常見的定時器
1)藉助Java.util.Timer來實現
2)OpenSymphony社區提供的Quartz來實現
3.介紹Timer
利用Timer開發定時任務是主要分爲兩個步驟:
1)建立定時任務類
示例代碼:
package org.lzstone.action
import java.util.TimeTask
public class LzstoneTimeTask extends TimeTask{
       public void run(){
              //執行的定時器任務
       }
}
2)運行定時任務,運行定時任務分爲兩種方式:
2.1)程序直接啓動
示例代碼:
package org.lzstone.action
public class LzstoneMain{
       .......
       public void run(){
        //執行定時器的任務
        //建立實例
        Timer timer = new Timer();
        參數:
        new LzstoneTimeTask()- 所要安排的任務。
        0- 執行任務前的延遲時間,單位是毫秒。
        1*1000- 執行各後續任務之間的時間間隔,單位是毫秒。
        timer.schedule(new LzstoneTimeTask(),0,1*1000);
       }
}
2.2)web監聽方式
示例代碼:
package org.lzstone.action
public class LzstoneMain implements ServletContextListener{
       private Timer timer = null;
       //初始化監聽器,建立實例,執行任務
       public void contextInitialized(ServletContextEvent event){
               timer = new Timer();
               timer.schedule(new LzstoneTimeTask(),0,1*1000);
       }
       //銷燬監聽器,中止執行任務
       public void contextDestroyed(ServletContextEvent event){
              //注意,在此計時器調用的計時器任務的 run 方法內調用此方法,就能夠絕對確保正在執行的任務是此計時器所執行的最後一個任務。
              timer.cancel();
        }
}
web.xml配置
<listener>
   <listener-class>
        org.lzstone.action.LzstoneMain
   </listener-class>
</listener>
4. 介紹Quartz
Quartz是OpenSymphony開源組織在Job scheduling領域又一個開源項目,能夠用來建立簡單或者複雜的定時任務,利用Quartz開發定時任務的步驟與Timer類

似。

利用Quartz開發定時任務是主要分爲兩個步驟:
1)建立定時任務類
示例代碼:
package org.lzstone.action
public class LzstoneTimeTask implements Job{
       public void execute(JobExecutionContext context) throws JobExecutionException{
              //執行的定時器任務
       }
}
2)運行定時任務,運行定時任務分爲兩種方式:
2.1)程序直接啓動,建立任務調度器及配置相應的任務計劃
示例代碼:
package org.lzstone.action
public class LzstoneMain{
       private static Scheduler sched;
       public static void run() throws Exception{
              //建立LzstoneTimeTask的定時任務
              JobDetail jobDetail = new JobDetail("lzstoneJob",sched.DEFAULT_GROUP,LzstoneTimeTask.class);
              //目標 建立任務計劃
              CronTrigger trigger = new CronTrigger("lzstoneTrigger","lzstone","0 0 12 * * ?");
              //0 0 12 * * ? 表明天天的中午12點觸發
              sched = new org.quartz.impl.StdSchedulerFactory().getScheduler();
              sched.scheduleJob(jobDetail,trigger);
              sched.start();
       }
       //中止
       public static void stop() throws Exception{
              sched.shutdown();
        }
}
//執行
public class Main{
       .............
       public void run(){
            LzstoneMain.run();
       }
       ............
}
2.2)web監聽方式
示例代碼:
package org.lzstone.action
public class LzstoneMainListener implements ServletContextListener{
       private Timer timer = null;
       //初始化監聽器,建立實例,執行任務
       public void contextInitialized(ServletContextEvent event){
               LzstoneMain.run();
       }
       //銷燬監聽器,中止執行任務
       public void contextDestroyed(ServletContextEvent event){
              LzstoneMain.stop();
        }
}
web.xml配置
<listener>
   <listener-class>
        org.lzstone.action.LzstoneMainListener
   </listener-class>
</listener>
5.對比
Timer方式實現定時器,原理簡單,實現方便,在執行簡單的任務比較方便,不足之處是沒法肯定執行時間,而且依賴性比較強,必須繼承指定的類
Quartz方式實現定時器,方便,清晰指定啓動時間,定時參數比較靈活,容易實現比較複雜的定時任務,不足之處是須要實現特定接口,加載其框架
兩種方式各有優缺點,在特定場合能夠根據其特色選擇使用。
6.Spring定時任務
Spring定時任務對Timer與Quartz都提供了支持,而且實現步驟基本同樣
首先配置Spring對Timer的支持
1.1 建立定時任務類
package org.lzstone.action
import java.util.TimeTask
public class LzstoneTimeTask extends TimeTask{
       public void run(){
              //執行的定時器任務
       }
}
1.2 註冊定時任務類,配置任務計劃與任務調度器
    在項目的WEB-INF下面建立TimerConfig.xml文件(通常叫作applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
<bean>
<!--註冊定時執行任務實體-->
<bean id="lzstoneTimeTask" class="org.lzstone.action.LzstoneTimeTask"/>
<!--註冊定時器信息-->
<bean id="taskInfo" class="org.springframework.scheduling.timer.ScheduledTimerTask">
<!--第一次執行任務前須要等待的時間,這裏設置爲3秒-->
<property name="delay">
<value>3000</value>
</property>
<!--設置任務的執行週期 這裏設置爲4秒-->
<property name="period">
  <value>4000</value>
</property>
<!--設置具體執行的任務 這裏設置爲lzstoneTimeTask-->
<property name="timerTask">
<ref local="lzstoneTimeTask"/>
</property>
</bean>
<!--配置定時器任務的調度器-->
<bean id="timerFactory" class="org.springframework.scheduling.timer.TimerFactoryBean">
<!--註冊定時器列表-->
<property name="scheduledTimerTasks">
    <list>
        <ref local="taskInfo"/>
        ........
    </list>
</property>
</bean>
</beans>
1.3 web項目中的啓動設置
    <context-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>/WEB-INF/TimerConfig.xml</param-value>
     </context-param>

     <listener>
         <listener-class>
                  org.springframework.web.context.ContextLoaderListener
         </listener-class>
     </listener>
配置Spring對Quartz的支持
2.1 建立定時任務類
package org.lzstone.action
public class LzstoneQuartzTask{
       public void execute(){
              //執行的定時器任務
       }
}
2.2 註冊定時任務類,配置任務計劃與任務調度器
    在項目的WEB-INF下面建立QuartzConfig.xml文件(通常叫作applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING//DTD BEAN//EN" "http://www.springframework.org/dtd/spring-beans.dtd">
<beans>
<bean>
<!--註冊定時執行任務實體-->
<bean id="lzstoneQuartzTask" class="org.lzstone.action.LzstoneQuartzTask"/>
<!--註冊定時器信息-->
<bean id="taskInfo" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<!--指定要執行的定時任務類  這裏是LzstoneQuartzTask-->
<property name="targetObject">
<ref local="lzstoneQuartzTask"/>
</property>
<!--指定定時器任務類要執行的方法名稱 這裏是execute-->
<property name="targetMethod">
<value>execute</value>
</property>
</bean>
<!--配置定時器任務的調度器-->
<bean id="quartzTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<!--聲明要運行的實體-->
<property name="jobDetail">
    <ref local="taskInfo"/>
</property>
<!--設置運行時間-->
<property name="cronExpression">
    <value>0 0 12 * * ?</value>
</property>
</bean>
<!--註冊監聽器-->
<bean id="registerQuartz" class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<!--註冊定時器實體 集合-->
<property name="triggers">
    <list>
          <ref local="quartzTrigger"/>
    </list>
</property>
</bean>
</beans>
2.3 web項目中的啓動設置
    <context-param>
      <param-name>contextConfigLocation</param-name>
      <param-value>/WEB-INF/QuartzConfig.xml</param-value>
     </context-param>

     <listener>
         <listener-class>
                  org.springframework.web.context.ContextLoaderListener
         </listener-class>
     </listener>web