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

  • 相关阅读:
    kotlin异常类
    kotlin之null值安全性
    kotlin之操作符重载
    kotlin 之相等判断
    Java 的抽象特性:抽象类与接口深度解析
    人人都能够做深度学习应用:入门篇
    HBase源代码分析之HRegionServer上MemStore的flush处理流程(一)
    通讯录结构体方法的实现 和VS中存在的一些问题的分析
    2015爱奇艺暑期实习生面试
    cocos2d-x 源代码分析 : EventDispatcher、EventListener、Event 源代码分析 (新触摸机制,新的NotificationCenter机制)
  • 原文地址:https://www.cnblogs.com/silyvin/p/9370501.html
Copyright © 2011-2022 走看看