1. /**
  2. * 普通thread
  3. * 这是最常见的,创建一个thread,然后让它在while循环里一直运行着,
  4. * 通过sleep方法来达到定时任务的效果。这样可以快速简单的实现,代码如下:
  5. *
  6. */
  7. public class Task1 {
  8. public static void main(String[] args) {
  9. // run in a second
  10. final long timeInterval = 1000;
  11. Runnable runnable = new Runnable() {
  12. public void run() {
  13. while (true) {
  14. // ------- code for task to run
  15. System.out.println("Hello !!");
  16. // ------- ends here
  17. try {
  18. Thread.sleep(timeInterval);
  19. } catch (InterruptedException e) {
  20. e.printStackTrace();
  21. }
  22. }
  23. }
  24. };
  25. Thread thread = new Thread(runnable);
  26. thread.start();
  27. }
  28. }
 
 
  1. /**
  2. *
  3. * 于第一种方式相比,优势 1>当启动和去取消任务时可以控制 2>第一次执行任务时可以指定你想要的delay时间
  4. *
  5. * 在实现时,Timer类可以调度任务,TimerTask则是通过在run()方法里实现具体任务。 Timer实例可以调度多任务,它是线程安全的。
  6. * 当Timer的构造器被调用时,它创建了一个线程,这个线程可以用来调度任务。 下面是代码:
  7. *
  8. */
  1. import java.util.Timer;
  2. import java.util.TimerTask;
  3. public class Task2 {
  4. public static void main(String[] args) {
  5. TimerTask task = new TimerTask() {
  6. @Override
  7. public void run() {
  8. // task to run goes here
  9. System.out.println("Hello !!!");
  10. }
  11. };
  12. Timer timer = new Timer();
  13. long delay = 0;
  14. long intevalPeriod = 1 * 1000;
  15. // schedules the task to be run in an interval
  16. timer.scheduleAtFixedRate(task, delay, intevalPeriod);
  17. timer.schedule(task, delay);
  18. } // end of main
  19. }
 
 
  1. /**
  2. * ScheduledExecutorService是从Java SE5的java.util.concurrent里,做为并发工具类被引进的,这是最理想的定时任务实现方式。
  3. * 相比于上两个方法,它有以下好处:
  4. * 1>相比于Timer的单线程,它是通过线程池的方式来执行任务的
  5. * 2>可以很灵活的去设定第一次执行任务delay时间
  6. * 3>提供了良好的约定,以便设定执行的时间间隔
  7. *
  8. * 下面是实现代码,我们通过ScheduledExecutorService#scheduleAtFixedRate展示这个例子,通过代码里参数的控制,首次执行加了delay时间。
  9. *
  10. */
    1. import java.util.concurrent.Executors;
    2. import java.util.concurrent.ScheduledExecutorService;
    3. import java.util.concurrent.TimeUnit;
    4. public class Task3 {
    5. public static void main(String[] args) {
    6. Runnable runnable = new Runnable() {
    7. public void run() {
    8. // task to run goes here
    9. System.out.println("Hello !!");
    10. }
    11. };
    12. ScheduledExecutorService service = Executors
    13. .newSingleThreadScheduledExecutor();
    14. // 第二个参数为首次执行的延时时间,第三个参数为定时执行的间隔时间
    15. service.scheduleAtFixedRate(runnable, 10, 1, TimeUnit.SECONDS);
    16. //        创建并执行在给定延迟后启用的 ScheduledFuture。
      //        参数:
      //        callable - 要执行的功能
      //        delay - 从现在开始延迟执行的时间
      //        unit - 延迟参数的时间单位
      //        返回:
      //        可用于提取结果或取消的 ScheduledFuture
    17. service.schedule(runnable, delay, TimeUnit.MILLISECONDS);
    18. }
    19. }

Java定时任务的几种方法(Thread 和 Timer,线程池)的更多相关文章

  1. java实现定时任务的三种方法 - 转载

    java实现定时任务的三种方法 /** * 普通thread * 这是最常见的,创建一个thread,然后让它在while循环里一直运行着, * 通过sleep方法来达到定时任务的效果.这样可以快速简 ...

  2. Java 字符串拼接 五种方法的性能比较分析 从执行100次到90万次

    [请尊重原创版权,如需引用,请注明来源及地址] > 字符串拼接一般使用“+”,但是“+”不能满足大批量数据的处理,Java中有以下五种方法处理字符串拼接,各有优缺点,程序开发应选择合适的方法实现 ...

  3. 斐波那契数列-java编程:三种方法实现斐波那契数列

    题目要求:编写程序在控制台输出斐波那契数列前20项,每输出5个数换行 斐波那契数列指的是这样一个数列:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, … 这个数列 ...

  4. PostgreSQL 实现定时任务的 4 种方法

    数据库定时任务可以用于实现定期的备份.统计信息采集.数据汇总.数据清理与优化等.PostgreSQL 没有提供类似 Oracle.MySQL 以及 Microsoft SQL Sever 的内置任务调 ...

  5. Eclipse远程调试Java代码的三种方法

    Eclipse远程调试Java代码的三种方法, 第1种方法是用来调试已经启动的Java程序,Eclipse可以随时连接到远程Java程序进行调试, 第2种方法可以调试Java程序启动过程,但是Ecli ...

  6. 《java.util.concurrent 包源码阅读》13 线程池系列之ThreadPoolExecutor 第三部分

    这一部分来说说线程池如何进行状态控制,即线程池的开启和关闭. 先来说说线程池的开启,这部分来看ThreadPoolExecutor构造方法: public ThreadPoolExecutor(int ...

  7. 【C++11应用】基于C++11及std::thread实现的线程池

    目录 基于C++11及std::thread实现的线程池 基于C++11及std::thread实现的线程池 线程池源码: #pragma once #include <functional&g ...

  8. [转]Java实现定时任务的三种方法

    在应用里经常都有用到在后台跑定时任务的需求.举个例子,比如需要在服务后台跑一个定时任务来进行非实时计算,清除临时数据.文件等.在本文里,我会给大家介绍3种不同的实现方法: 普通thread实现 Tim ...

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

    /** * 普通thread * 这是最常见的,创建一个thread,然后让它在while循环里一直运行着, * 通过sleep方法来达到定时任务的效果.这样可以快速简单的实现,代码如下: * @au ...

随机推荐

  1. 掌握Pod-Pod调度策略

    一 Pod生命周期管理 1.1 Pod生命周期 Pod在整个生命周期过程中被系统定义了如下各种状态. 状态值 描述 Pending API Server已经创建该Pod,且Pod内还有一个或多个容器的 ...

  2. HBITMAP与BITMAP 的区别

    HBITMAP   是句柄:  BITMAP    是实例:    typedef   struct   tagBITMAP {             LONG       bmType;      ...

  3. 组件推荐Forloop.HtmlHelpers 用来实现MVC的js加载顺序

    最近在开发的时候遇到js加载顺序的问题,layui在底部声明了js,但是我想在页面其他地方使用分布视图,分布视图内有自己的js逻辑,发现不能执行,一看就发现,这里的js应该加在layui后面执行才能有 ...

  4. SQLSERVER去除某一列的重复值并显示所有数据\DISTINCT去重\ISNULL()求SUM()\NOT EXISTS的使用

    进入正题,准备我们的测试数据 1.我们要筛选的数据为去除 GX 列的重复项 并将所有数据展示出来,如图所示: ' 2.这种情况下我们是不可以使用DISTINCT来去重的,我们可以来尝试一下: 首先,单 ...

  5. Tensorf实战第九课(自编码AutoEncoder)

    本节我们将了解神经网络进行非监督形式的学习,即autoencoder自编码 假设图片经过神经网络后再输出的过程,我们看作是图片先被压缩然后解压的过程.那么在压缩的时候,原有的图片质量被缩减,解压时用信 ...

  6. elasticsearch的cross_fields查询

    1.most_fields 这种方式搜索也存在某些问题 它不能使用 operator 或 minimum_should_match 参数来降低次相关结果造成的长尾效应. 2.词 peter 和 smi ...

  7. Java内存模型(三)原子性、内存可见性、重排序、顺序一致性、volatile、锁、final

          一.原子性 原子性操作指相应的操作是单一不可分割的操作.例如,对int变量count执行count++d操作就不是原子性操作.因为count++实际上可以分解为3个操作:(1)读取变量co ...

  8. Mongo分片+副本集集群搭建

    一. 概念简单描述 1. MongoDB分片集群包含组件: mongos,configserver,shardding分片 2. Mongos:路由服务是Sharded cluster的访问入口,本身 ...

  9. hadoop3.1.2启动和停止

    1/  启动 启动zookeeper: 三个节点上都zkServer.sh start 启动hdfs和yarn: 101上start-dfs.sh  102上start-yarn.sh 启动hive: ...

  10. [转帖]IBM收购红帽价格是多少?是否会形成垄断企业?会存在什么不安因素?

    http://www.techweb.com.cn/it/2019-07-10/2743776.shtml 国产的linux 用centos源的 如何是好呢.. 蓝色巨人IBM官方宣布,已经正式完成对 ...