zoukankan      html  css  js  c++  java
  • scheduleAtFixedRate scheduleWithFixedDealy / Timer ScheduledExecutorService 区别

    1、scheduleAtFixedRate 方法,顾名思义,它的方法名称的意思是:已固定的频率来执行某项计划(任务)。

    2、scheduleWithFixedDealy,相对固定的延迟后,执行某项计划。

    第一个方法是固定的频率来执行某项计划,它不受计划执行时间的影响。到时间,它就执行。

    而第二个方法,相对固定,据鄙人理解,是相对任务的。即无论某个任务执行多长时间,等执行完了,我再延迟指定的时间。也就是第二个方法,它受计划执行时间的影响。

    两种方法,对异常都很敏感,一旦有异常,线程(非线程池)后续该任务不再执行,解决方案是对run函数全程try catch保护

    ScheduledExecutorService Timer  
    scheduleAtFixedRate scheduleAtFixedRate 固定间隔
    scheduleWithFixedDealy schedule 固定频率
          异常
    Timer 单线程 多个任务顺序执行,不同任务会延时 线程池所有任务挂掉
    ScheduledExecutorService 指定线程

    多个任务并发执行,只要线程够,多个任务排除自身运行太久,都能准时执行

    将corePoolSize设置为1,变成单线程跑呢?结果当然是和Timer一样,任务B会导致任务A延迟执行,不过比较好的是任务C抛异常不会影响到其他任务的调度。

    线程下后续该任务挂掉

    https://blog.csdn.net/guozebo/article/details/51090612

    package Thread;
    
    import java.util.TimerTask;
    import java.util.concurrent.Executors;
    import java.util.concurrent.ScheduledExecutorService;
    import java.util.concurrent.TimeUnit;
    
    /**
     * Created by sunyuming on 18/10/23.
     */
    public class MySchedule {
        public static void main(String[] args) {
            int corePoolSize = 1;
            ScheduledExecutorService pool = Executors.newScheduledThreadPool(corePoolSize);
    
            pool.scheduleAtFixedRate(new TimerTask() {
                @Override
                public void run() {
                    System.out.println('a');
                }
            }, 0, 10, TimeUnit.SECONDS);
    
            pool.scheduleAtFixedRate(new TimerTask() {
                @Override
                public void run() {
                    System.out.println('b');
                }
            }, 0, 10, TimeUnit.SECONDS);
    
            pool.scheduleAtFixedRate(new TimerTask() {
                @Override
                public void run() {
                    System.out.println('c');
                    throw new RuntimeException("test");
                }
            }, 0, 10, TimeUnit.SECONDS);
        }
    }
    

    a
    b
    c
    a
    b
    a
    b

  • 相关阅读:
    iOS中多线程的实现方案
    初识多线程
    《文献管理与信息分析》第一讲学习总结
    《构建之法》第一章读书摘要
    Total Commander的初次体验
    学习《深入理解计算机系统》第一章摘要
    Vim编辑器的学习
    关于《文献管理与信息分析》的一些问题
    阅读《构建之法》后所产生的问题
    阅读《深入理解计算机系统(第三版)》产生的一些疑惑和困惑
  • 原文地址:https://www.cnblogs.com/silyvin/p/9370501.html
Copyright © 2011-2022 走看看