【Quartz】2、Job与JobDetail

这篇博客介绍了在Quartz中如何处理Job的状态变量,包括JobExecutionContext和JobDetail的作用。文章通过示例展示了JobDataMap在Job执行过程中的作用,解释了@PersistJobDataAfterExecution注解对于数据持久化的重要性,以及@DisallowConcurrentExecution注解防止并发执行的机制。最后,提到了可以通过设置JobDataMap中数据的set方法简化数据获取流程。
摘要由CSDN通过智能技术生成

Quartz概述中提到,Job类定义了具体任务内容,只需要实现Quartz.Job接口并实现execute()方法即可,Job类方法如下图所示:

同时,前面也提到Job实例的execute()方法在执行前会创建新的实例,执行结束后被销毁,作为垃圾回收。可以进行一个非常简单的试验,改写HelloJob.class为HelloJob2.class:

public class SayHello2 implements Job {
   
	int count = 0 ;
	public void  addCount(){
   
		count++;
	}
	//定义待执行的任务
	@Override
	public void execute(JobExecutionContext jobExecutionContext) throws JobExecutionException {
   
		addCount();
		System.out.println("Hello Quartz !" + new Date()+"count:"+ count);
	}
}

在新的类中添加变量count用以记录execute()方法执行的次数,程序启动后发现count的值并不会随着execute()方法的执行而累加,执行结果如下图所示。这说明,在Job类中定义状态变量是行不通的。

要想在Job执行的过程中储存或使用状态变量怎么办呢?此处与之相关的内容有两个:JobExecutionContext与JobDetail,在Job类的execute()方法中传入的参数即为JobExecutionContext对象,该对象中储存了相关的上下文信息,类似于spring框架中的ApplicationContext,其中定义的方法如下图所示。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值