在Java中为我们提供了Timer来实现定时任务,当然现在还有很多定时任务框架,比如说Spring、QuartZ、Linux Cron等等,而且性能也更加优越。但是我们想要深入的学习就必须先从最简单的开始。
第一种:
创建一个thread,然后让它在while循环里一直运行着,通过sleep方法来达到定时任务的效果,代码如下
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | public class Task1 { public static void main(String[] args) { // run in a second // 每一秒钟执行一次 final long timeInterval = 1000 ; Runnable runnable = new Runnable() { public void run() { while ( true ) { // ------- code for task to run // ------- 要运行的任务代码 System.out.println( "Hello, stranger" ); // ------- ends here try { // sleep():同步延迟数据,并且会阻塞线程 Thread.sleep(timeInterval); } catch (InterruptedException e) { e.printStackTrace(); } } } }; //创建定时器 Thread thread = new Thread(runnable); //开始执行 thread.start(); } } |
第二种:
启动和去取消任务时可以控制,可以指定你想要的delay(开始执行的等待时间)时间,在实现时,Timer类可以调度任务,TimerTask则是通过在run()方法里实现具体任务。 Timer实例可以调度多任务,它是线程安全的。 当Timer的构造器被调用时,它创建了一个线程,这个线程可以用来调度任务。代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | // 调用的工具 import java.util.Timer; import java.util.TimerTask; public class Task2 { public static void main(String[] args) { /** * Timer:是一个定时器工具,用来执行指定任务 * TimerTask:是一个抽象类,他的子类可以代表一个被Timer计划的任务 */ TimerTask task = new TimerTask() { @Override public void run() { // task to run goes here // 执行的输出的内容 System.out.println( "Hello, stranger" ); } }; Timer timer = new Timer(); // 定义开始等待时间 --- 等待 5 秒 // 1000ms = 1s long delay = 5000 ; // 定义每次执行的间隔时间 long intevalPeriod = 5 * 1000 ; // schedules the task to be run in an interval // 安排任务在一段时间内运行 timer.scheduleAtFixedRate(task, delay, intevalPeriod); } // end of main } |
第三种:
相比于上两个方法,它有以下好处:
1.相比于Timer的单线程,它是通过线程池的方式来执行任务的
2.可以很灵活的去设定第一次执行任务delay时间
3.提供了良好的约定,以便设定执行的时间间隔
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 | //调用的工具 import java.util.concurrent.Executors; import java.util.concurrent.ScheduledExecutorService; import java.util.concurrent.TimeUnit; public class Task3 { public static void main(String[] args) { /** * Runnable:实现了Runnable接口,jdk就知道这个类是一个线程 */ Runnable runnable = new Runnable() { //创建 run 方法 public void run() { // task to run goes here System.out.println( "Hello, stranger" ); } }; // ScheduledExecutorService:是从Java SE5的java.util.concurrent里, // 做为并发工具类被引进的,这是最理想的定时任务实现方式。 ScheduledExecutorService service = Executors .newSingleThreadScheduledExecutor(); // 第二个参数为首次执行的延时时间,第三个参数为定时执行的间隔时间 // 10:秒 5:秒 // 第一次执行的时间为10秒,然后每隔五秒执行一次 service.scheduleAtFixedRate(runnable, 10 , 5 , TimeUnit.SECONDS); } } |
转载自:https://blog.csdn.net/qq_36537546/article/details/83044977
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
2015-01-14 plsql中文乱码