不用任何框架,Java 就能实现定时任务的 3 种方法
1、 sleep
实现逻辑:
新开一个线程,添加一个 for/ while 死循环,然后在死循环里面添加一个 sleep 休眠逻辑,让程序每隔 N 秒休眠再执行一次,这样就达到了一个简单定时任务的效果。
/**
* 休眠实现定时任务
* 来源公众号:Java技术栈
*/
private static void sleepTask() {
new Thread(() -> {
while (true) {
System.out.println("hi, 欢迎关注:Java技术栈");
try {
// 每隔3秒执行一次
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}).start();
}
2、Timer
几个重要的方法:
- schedule:开始调度任务,提供了几个包装方法;
- cancle:终止任务调度,取消当前调度的所有任务,正在运行的任务不受影响;
- purge:从任务队列中移除所有已取消的任务;
另外,java.util.TimerTask 就是实现了 Runnable 接口,具体任务逻辑则是在 run 方法里去实现。
/**
* timer定时任务
* 来源公众号:Java技术栈
*/
private static void timerTask() throws InterruptedException {
Timer timer = new Timer();
TimerTask timerTask = new TimerTask() {
@Override
public void run() {
System.out.println("hi, 欢迎关注:Java技术栈");
}
};
// 第一次任务延迟时间
long delay = 2000;
// 任务执行频率
long period = 3 * 1000;
// 开始调度
timer.schedule(timerTask, delay, period);
// 指定首次运行时间
// timer.schedule(timerTask, DateUtils.addSeconds(new Date(), 5), period);
Thread.sleep(20000);
// 终止并移除任务
timer.cancel();
timer.purge();
}
3、ScheduledExecutorService
- schedule:只执行一次调度;
- scheduleAtFixedRate:按固定频率调度,如果执行时间过长,下一次调度会延迟,不会同时执行;
- scheduleWithFixedDelay:延迟调度,上一次执行完再加上延迟时间后执行;
另外,可以看出,任务是支持 Runnable 和 Callable 调度的。
/**
* 线程池定时任务
* 来源公众号:Java技术栈
*/
public static void poolTask(){
ScheduledExecutorService pool = Executors.newScheduledThreadPool(10);
pool.scheduleAtFixedRate(() -> {
System.out.println("hi, 欢迎关注:Java技术栈");
}, 2000, 3000, TimeUnit.MILLISECONDS);
}
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战