浅谈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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值