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

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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值