quartz demo

QuartzJob 类:创建job类,实现org.quartz.job接口类,并实现execute方法。

<!-- lang: java -->
package com.pgw.quartz;
import java.util.Date;
import org.quartz.Job;
import org.quartz.JobExecutionContext;
import org.quartz.JobExecutionException;

public class QuartzJob implements Job{
	public void execute(JobExecutionContext arg0) throws JobExecutionException {
		System.out.println("Hello world !!!" + new Date());
	}
}

QuartzCronTrigger 类:创建crontrigger类,继承CronTrigger类,实现 Serializable接口

<!-- lang: java -->
package com.pgw.quartz;
import java.io.Serializable;
import java.text.ParseException;
import org.quartz.CronTrigger;

public class QuartzCronTrigger extends CronTrigger implements Serializable{
	private static final long serialVersionUID = 1L;
	
	public QuartzCronTrigger(){
		
	}
	
	public void setCronExpress(String corn, String name, String groupName){
		try {
			this.setCronExpression(corn);
			this.setName(name);
			this.setGroup(groupName);
		} catch (ParseException e) {
			e.printStackTrace();
		}
	}
}

QuartzMain 类

1、如果Scheduler没有设置名称,通过scheduler = factory.getDefaultScheduler();获取的Scheduler对象名称为DefaultQuartzScheduler。

2、Quartz可以设置一个Scheduler,然后在这个Scheduler下配置多对trigger和job度对象。

<!-- lang: java -->
package com.pgw.quartz;
import org.quartz.CronTrigger;
import org.quartz.JobDetail;
import org.quartz.Scheduler;
import org.quartz.impl.StdSchedulerFactory;

public class QuartzMain{
	public static void main(String[] args) {
		// 创建一个jobDetail对象,将Job实际业务类放入jobDetail中
		JobDetail jobDetail = new JobDetail("demo", "demo", QuartzJob.class);
		// 创建一个触发器
		CronTrigger triggers = new QuartzCronTrigger();
		try {
			// 设置触发器 名字
			triggers.setName("demo");
			// 设置触发器所属组
			triggers.setGroup("demo");
			// 设置触发时间cron表达式
			triggers.setCronExpression("10 * * * * ?");
			// 将jobDetail放入触发器中
			triggers.setJobGroup("demo");
		
			// 创建schedulerFactory对象
			StdSchedulerFactory factory = new StdSchedulerFactory();
			
			Scheduler scheduler = factory.getDefaultScheduler();
		    // Register the JobDetail and Trigger
			scheduler.scheduleJob(jobDetail, triggers);
			
		    // 挂起定时线程
			scheduler.start();
		}catch(Exception ex){
				ex.printStackTrace();
		}
	}
}

转载于:https://my.oschina.net/u/225084/blog/170831

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值