java Timer(定时调用、实现固定时间执行)测试

本文通过两个测试案例展示了Java中Timer类的行为特点。测试1:任务执行时间小于重复执行间隔时间时,任务能按预期频率执行;测试2:任务执行时间大于重复执行间隔时间时,任务会在上一个任务完成后立即开始执行下一个任务,导致执行间隔时间变长。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

java Timer(定时调用、实现固定时间执行)测试

测试1,当任务执行时间小于重复执行的间隔时间

代码:

public class TimerTest2 {
    public static void main(String[] args) throws InterruptedException {
        Timer timer = new Timer();
        timer.schedule(new MyTask(0), 1000, 10000);
        //timer.schedule(new MyTask(1), 1000, 10000);
    }

    static class MyTask extends TimerTask {
        private final int i;
        public MyTask(int i) {
            this.i = i;
        }

        @Override
        public void run() {
            System.out.println(i + "dddd" + DateTimeUtil.getDateTimeString("yyyy-MM-dd HH:mm:ss.SSS"));
            try {
                if (i == 0) {
                    Thread.sleep(8000L);
                } else {
                    Thread.sleep(13000L);
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}

结果:
0dddd2018-01-11 15:34:57.826
0dddd2018-01-11 15:35:07.824
0dddd2018-01-11 15:35:17.824
0dddd2018-01-11 15:35:27.824
0dddd2018-01-11 15:35:37.824
0dddd2018-01-11 15:35:47.824
0dddd2018-01-11 15:35:57.824
0dddd2018-01-11 15:36:07.824
0dddd2018-01-11 15:36:17.824
0dddd2018-01-11 15:36:27.824
0dddd2018-01-11 15:36:37.824
0dddd2018-01-11 15:36:47.824
0dddd2018-01-11 15:36:57.824
0dddd2018-01-11 15:37:07.824
0dddd2018-01-11 15:37:17.824
0dddd2018-01-11 15:37:27.824
0dddd2018-01-11 15:37:37.824


测试2,当任务执行时间大于重复执行的间隔时间

代码:

public class TimerTest2 {
    public static void main(String[] args) throws InterruptedException {
        Timer timer = new Timer();
        //timer.schedule(new MyTask(0), 1000, 10000);
        timer.schedule(new MyTask(1), 1000, 10000);
    }

    static class MyTask extends TimerTask {
        private final int i;
        public MyTask(int i) {
            this.i = i;
        }

        @Override
        public void run() {
            System.out.println(i + "dddd" + DateTimeUtil.getDateTimeString("yyyy-MM-dd HH:mm:ss.SSS"));
            try {
                if (i == 0) {
                    Thread.sleep(8000L);
                } else {
                    Thread.sleep(13000L);
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
}

结果:
1dddd2018-01-11 16:03:07.575
1dddd2018-01-11 16:03:20.601
1dddd2018-01-11 16:03:33.602
1dddd2018-01-11 16:03:46.603
1dddd2018-01-11 16:03:59.604
1dddd2018-01-11 16:04:12.606
1dddd2018-01-11 16:04:25.607
1dddd2018-01-11 16:04:38.608

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值