浅谈job&jobDetail

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();
        }
    }
}

结果:

原文地址:https://www.cnblogs.com/qlqwjy/p/8721867.html