栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java 定时器

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java 定时器

1、Timer定时器(一般不会用)

可使用 public Timer()构造器创建Timer对象

使用方法schedule(TimerTask task,long delay,long period)来开启一个定时器,按照计划处理TimerTask任务。

import java.util.Timer;
import java.util.TimerTask;

public class TimerDemo1 {
    public static void main(String[] args) {
        //1、创建定时器对象
        Timer timer=new Timer();
        //2、调用方法,处理定时任务
        timer.schedule(new TimerTask() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"执行了一次");
            }
        },2000,3000);
        //等两秒开始运行,隔三秒运行一次
    }
}

Timer定时器的特点和存在的问题

1、Timer时单线程,处理多个任务时排队进行,存在延时与设置定时器的时间有出入

2、可能会因为某个任务异常使Timer线程死掉,影响后续任务执行

因此引入了ScheduledExercutorService定时器

2、*ScheduledExercutorService定时器(内部为线程池)

Exercutor的方法:newScheduledThreadPool(int corePoolSize) 得到线程池对象

ScheduledExercutorService的方法:

public ScheduledFuture scheduleAtFixedRate(Runnable command, long initialDelay, long period,TimeUnit unit)

参数一:TimerTask任务(实现了Runnable接口)

参数二:多长时间后开始执行

参数三:隔多长时间执行一次

参数四:时间单位

import java.util.TimerTask;
import java.util.concurrent.*;


public class TimerDemo2 {
    public static void main(String[] args) {
        ScheduledExecutorService pool= Executors.newScheduledThreadPool(3);
        pool.scheduleAtFixedRate(new TimerTask() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"执行输出AAA");
//                try {
//                    Thread.sleep(50000);
//                } catch (Exception e) {
//                    e.printStackTrace();
//                }
                System.out.println(10/0);
            }//睡眠和异常都不会影响其他线程的任务
        },2,2, TimeUnit.SECONDS);
        //这里线程池定时器,一个线程池遇到异常或处理时间较长的任务时,不会影响其他线程的执行
        pool.scheduleAtFixedRate(new TimerTask() {
            @Override
            public void run() {
                    System.out.println(Thread.currentThread().getName()+"执行输出BBB");
            }
        },2,5, TimeUnit.SECONDS);
    }
}

优点:基于线程池,某个任务的执行不会影响其他任务

一般使用ScheduledExercutorService。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/727084.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号