java实现定时任务的三种方法

2018-01-17 15:58:16

[java] view plain copy

  1. /** 

  2.  * 普通thread 

  3.  * 这是最常见的,创建一个thread,然后让它在while循环里一直运行着, 

  4.  * 通过sleep方法来达到定时任务的效果。这样可以快速简单的实现,代码如下: 

  5.  * @author GT 

  6.  * 

  7.  */  

  8. public class Task1 {  

  9.     public static void main(String[] args) {  

  10.         // run in a second  

  11.         final long timeInterval = 1000;  

  12.         Runnable runnable = new Runnable() {  

  13.             public void run() {  

  14.                 while (true) {  

  15.                     // ------- code for task to run  

  16.                     System.out.println("Hello !!");  

  17.                     // ------- ends here  

  18.                     try {  

  19.                         Thread.sleep(timeInterval);  

  20.                     } catch (InterruptedException e) {  

  21.                         e.printStackTrace();  

  22.                     }  

  23.                 }  

  24.             }  

  25.         };  

  26.         Thread thread = new Thread(runnable);  

  27.         thread.start();  

  28.     }  

  29. }  



[java] view plain copy

  1. import java.util.Timer;  

  2. import java.util.TimerTask;  

  3.   

  4. /** 

  5.  *  

  6.  * 于第一种方式相比,优势 1>当启动和去取消任务时可以控制 2>第一次执行任务时可以指定你想要的delay时间 

  7.  *  

  8.  * 在实现时,Timer类可以调度任务,TimerTask则是通过在run()方法里实现具体任务。 Timer实例可以调度多任务,它是线程安全的。 

  9.  * 当Timer的构造器被调用时,它创建了一个线程,这个线程可以用来调度任务。 下面是代码: 

  10.  *  

  11.  * @author GT 

  12.  *  

  13.  */  

  14. public class Task2 {  

  15.     public static void main(String[] args) {  

  16.         TimerTask task = new TimerTask() {  

  17.             @Override  

  18.             public void run() {  

  19.                 // task to run goes here  

  20.                 System.out.println("Hello !!!");  

  21.             }  

  22.         };  

  23.         Timer timer = new Timer();  

  24.         long delay = 0;  

  25.         long intevalPeriod = 1 * 1000;  

  26.         // schedules the task to be run in an interval  

  27.         timer.scheduleAtFixedRate(task, delay, intevalPeriod);  

  28.     } // end of main  

  29. }  



[java] view plain copy

  1. import java.util.concurrent.Executors;  

  2. import java.util.concurrent.ScheduledExecutorService;  

  3. import java.util.concurrent.TimeUnit;  

  4.   

  5. /** 

  6.  *  

  7.  *  

  8.  * ScheduledExecutorService是从Java SE5的java.util.concurrent里,做为并发工具类被引进的,这是最理想的定时任务实现方式。  

  9.  * 相比于上两个方法,它有以下好处: 

  10.  * 1>相比于Timer的单线程,它是通过线程池的方式来执行任务的  

  11.  * 2>可以很灵活的去设定第一次执行任务delay时间 

  12.  * 3>提供了良好的约定,以便设定执行的时间间隔 

  13.  *  

  14.  * 下面是实现代码,我们通过ScheduledExecutorService#scheduleAtFixedRate展示这个例子,通过代码里参数的控制,首次执行加了delay时间。 

  15.  *  

  16.  *  

  17.  * @author GT 

  18.  *  

  19.  */  

  20. public class Task3 {  

  21.     public static void main(String[] args) {  

  22.         Runnable runnable = new Runnable() {  

  23.             public void run() {  

  24.                 // task to run goes here  

  25.                 System.out.println("Hello !!");  

  26.             }  

  27.         };  

  28.         ScheduledExecutorService service = Executors  

  29.                 .newSingleThreadScheduledExecutor();  

  30.         // 第二个参数为首次执行的延时时间,第三个参数为定时执行的间隔时间  

  31.         service.scheduleAtFixedRate(runnable, 101, TimeUnit.SECONDS);  

  32.     }  

  33. }  



  • 2021-04-15 10:11:17

    Puppeteer拦截修改返回值

    page.setRequestInterception(true)拦截器的使用方法和场景 现附上Puppeteer的Api的链接https://github.com/GoogleChrome/puppeteer/blob/master/docs/api.md

  • 2021-04-15 10:32:18

    怎么给 headless chrome添加cookies

    In puppeter you have access to the session cookies through page.cookies(). So once you log in, you could get every cookie and save it in a json file:

  • 2021-04-15 10:51:21

    如何通过Devtools协议拦截和修改Chrome响应数据

    在日常研究中,我们经常碰到大量JavaScript代码,我们首先要深入分析才能了解这些代码的功能及具体逻辑。这些代码代码可能会被恶意注入到页面中,可能是客户送过来需要我们帮忙分析的脚本,也可能是我们的安全团队在网页上找到的引用了我们服务的某些资源。这些脚本通常代码量不大、经过混淆处理,并且我们总是需要经过多层修改才能继续深入分析。

  • 2021-04-19 10:54:39

    block和delegate的区别

    代理 可读性高 大部分可以属性 block 写的代码少 一般作为参数 通知 占用资源

  • 2021-04-19 11:00:23

    浅谈block和delegate的使用

    委托是协议的一种,顾名思义,就是委托他人帮自己去做事。委托是给一个对象提供机会对另一个对象中的变化做出反应或者影响另一个对象的行为。其基本思想是:两个对象协同解决问题,并且打算在广泛的情形中重用。委托指向另一个对象(即它的委托)的引用,并在关键时刻给委托发消息。消息可能只是通知委托发生了某件事情,给委托提供机会执行额外的处理,或者消息可能要求委托提供一些关键的信息以控制所发生的事情。委托的作用主要有两个,一个是传值,一个是传事件。

  • 2021-04-19 11:36:44

    iOS 组件实现方案

    什么才是好架构,为什么要组件,组件设计的优点

  • 2021-04-25 09:53:18

    android debug速度特别慢有时候卡住

    一直提示定在 Starting LLDB server。可能的原因是 Android Studio编译速度太慢了,就会一直卡在Starting LLDB server。可以通过设置 Run/Debug Configurations ——> Debugger ——> Debug type 为 Java 跳过 C/C++的调试,起码实现对 Java 程序的调试