1.job简介
Job:接口非常容易实现,只有一个execute方法,类似于Timer的run方法,在里面编写业务逻辑。
job实例在quartz中的声明周期:
每次调度器在执行job时,它在执行execute方法前创建一个job实例
当调用完成之后,关联的job对象实例会被释放,释放的实例被垃圾回收期你回收。
2. jobDetail简介
JobDetail为Job实例提供了许多设置属性,以及JobDataMap成员变量属性,它用来存储特定job实例的状态信息系,调度器需要借助Jobdetail对象来添加Job实例。
重要属性:
name:任务的名称,必须属性
group:任务所在的组,也是必须,默认值是DEFAULT,必须的
jobclass:任务的实现类,必须的
jobdatamap:用于传递传参数
例如:将入门代码改造获取jobDetail的属性
package cn.qlq.quartz; import static org.quartz.DateBuilder.newDate; import static org.quartz.JobBuilder.newJob; import static org.quartz.SimpleScheduleBuilder.simpleSchedule; import static org.quartz.TriggerBuilder.newTrigger; import java.util.GregorianCalendar; import org.quartz.JobDetail; import org.quartz.Scheduler; import org.quartz.SimpleScheduleBuilder; import org.quartz.Trigger; import org.quartz.TriggerBuilder; import org.quartz.impl.StdSchedulerFactory; import org.quartz.impl.calendar.AnnualCalendar; public class HelloScheduler { public static void main(String[] args) { try { //1. 创建一个JodDetail实例 将该实例与Hello job class绑定 (链式写法) JobDetail jobDetail = newJob(HelloJob.class) // 定义Job类为HelloQuartz类,这是真正的执行逻辑所在 .withIdentity("myJob") // 定义name,默认组是DEFAULT .build(); System.out.println("jobDetail's name:"+jobDetail.getKey().getName()); System.out.println("jobDetail's group:"+jobDetail.getKey().getGroup()); System.out.println("jobDetail's jobClass:"+jobDetail.getJobClass().getName()); //2. 定义一个Trigger,定义该job立即执行,并且每两秒钟执行一次,直到永远 Trigger trigger = TriggerBuilder.newTrigger().withIdentity("myTrigger", "group1")// 定义名字和组 .startNow()//现在开始 .withSchedule(SimpleScheduleBuilder.simpleSchedule().withIntervalInSeconds(2).repeatForever()) .build(); //3. 创建scheduler Scheduler scheduler = StdSchedulerFactory.getDefaultScheduler(); //4. 将trigger和jobdetail加入这个调度 scheduler.scheduleJob(jobDetail, trigger); //5. 启动scheduler scheduler.start(); } catch (Exception e) { e.printStackTrace(); } } }
结果: