Vejamos diretamente o arquivo de configuração do Spring:
<?xml versão="1.0" codificação="UTF-8"?>
<beans xmlns=" http://www.springframework.org/schema/beans "
xmlns:xsi=" http://www.w3.org/2001/XMLSchema-instance "
xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd ">
<bean id="testTimerTask" class="com.test.timerTask.TestTimerTask"></bean>
<bean id="serviceFor" class="com.test.timerTask.Service4Job"></bean>
<!-- O primeiro passo: Definir a classe de agendamento de tarefas, ou seja, a classe que precisa realizar o trabalho de negócio. Existem duas situações, escolha uma para agendamento -->.
<!-- Classe de agendamento de tarefas caso 1: Use uma classe herdada da classe abstrata QuartzJobBean para implementar o agendamento de tarefas -->
<bean id="testTimerTaskJob" class="org.springframework.scheduling.quartz.JobDetailBean">
<!-- Observe que o nome completo da classe é injetado aqui, não uma referência à classe -->
<property name="jobClass" value="com.test.timerTask.TestTimerTask"></property>
<!-- Indica a injeção dos beans necessários na classe testTimerTask -->
<nome da propriedade="jobDataAsMap">
<mapa>
<entry key="service4Job" value-ref="serviceFor"></entry>
</mapa>
</propriedade>
</bean>
<!-- Caso 2 da classe de agendamento de tarefas: agendar métodos de negócios diretamente em classes existentes sem herdar de QuartzJobBean -->
<bean id="noJobBeanTaskJob" class="org.springframework.scheduling.quartz.MethodInvokingJobDetailFactoryBean">
<property name="targetObject" ref="serviceFor"></property>
<property name="targetMethod" value="job"></property>
</bean>
<!-- Passo 2: Definir o gatilho, indicando quando ou com que frequência agendar as tarefas definidas no primeiro passo -->
<!-- Caso de gatilho 1: baseado na chamada de tarefa SimpleTriggerBean -->
<bean id="quartzSimpleTrigger" class="org.springframework.scheduling.quartz.SimpleTriggerBean">
<property name="jobDetail" ref="testTimerTaskJob"></property>
<property name="repeatInterval" value="3000"></property>
<property name="startDelay" value="2000"></property>
</bean>
<!-- Caso de gatilho 2: baseado na chamada de tarefa SimpleTriggerBean -->
<bean id="quartzCronTrigger" class="org.springframework.scheduling.quartz.CronTriggerBean">
<property name="jobDetail" ref="noJobBeanTaskJob"></property>
<!-- A forma de string de cronExpression é usada aqui 0/3 significa execução a cada 3 segundos -->.
<property name="cronExpression" value="0/3 * * * * ?"></property>
</bean>
<!-- Etapa 3: iniciar o agendamento de tarefas -->
<!-- Comece a executar o gatilho de agendamento de tarefas-->
<bean class="org.springframework.scheduling.quartz.SchedulerFactoryBean">
<nome da propriedade="gatilhos">
<lista>
<ref bean="quartzCronTrigger"/>
</lista>
</propriedade>
</bean>
</feijão>
//============================================== ===
Duas classes: TestTimerTask e Service4Job
importar org.quartz.JobExecutionContext;
importar org.quartz.JobExecutionException;
importar org.springframework.scheduling.quartz.QuartzJobBean;
classe pública TestTimerTask estende QuartzJobBean{
serviço4Job privado service4Job;
public void setService4Job(Service4Job service4Job) {
this.service4Job = service4Job;
}
@Substituir
void protegido executeInternal(JobExecutionContext arg0)
lança JobExecutionException {
this.service4Job.job();
}
}
classe pública Service4Job {
trabalho vazio público(){
System.out.println("**** "+System.currentTimeMillis());
}
}
(este mês) Repostagem: http://yanda20056.blog.163.com/blog/static/5650193120091113115434635/
Este artigo vem do blog CSDN. Por favor, indique a fonte ao reimprimir: http://blog.csdn.net/thismonth/archive/2009/12/30/5103969.aspx.