使用Timer类schedule方法出现:java.lang.IllegalArgumentException:Illegal execution time

之前一个应用在新的机型上出现闪退的问题,还是必现,复现了下,看到log中出现java.lang.IllegalArgumentException:Illegal execution time的错误,锁定到代码中发现,错误出现在Timer的schedule方法中。

代码如下,中间的处理省略了。出这个问题很奇怪,llegalArgumentException此异常表明向方法传递了一个不合法或不正确的参数。可是传入的参数500也没有问题。

Timer timer = new Timer();
timer.schedule(new TimerTask() {
        public void run() {
            ...
        }
}, 500);

于是找了一下源码如下,发现time < 0的时候会抛出该错误,于是继续向上看是哪个函数调的这个sched函数。

private void sched(TimerTask task, long time, long period) {
        if (time < 0)
            throw new IllegalArgumentException("Illegal execution time.");

        synchronized(queue) {
            if (!thread.newTasksMayBeScheduled)
                throw new IllegalStateException("Timer already cancelled.");

            synchronized(task.lock) {
                if (task.state != TimerTask.VIRGIN)
                    throw new IllegalStateException(
                        "Task already scheduled or cancelled");
                task.nextExecutionTime = time;
                task.period = period;
                task.state = TimerTask.SCHEDULED;
            }

            queue.add(task);
            if (queue.getMin() == task)
                queue.notify();
        }
    }

sched向上的引用是schedule(TimerTask task, long delay),代码如下,发现传入的time是System.currentTimeMillis() + delay,也就是说如果我们传入的delay没有问题,那就是System.currentTimeMillis()有问题,最后写个应用,打印了一下System.currentTimeMillis(),打印出来是:- 950468026…….

public void schedule(TimerTask task, long delay) {
       if (delay < 0)
           throw new IllegalArgumentException("Negative delay.");
       sched(task, System.currentTimeMillis()+delay, 0);
   }

这个问题是系统的问题,时间没有校对正确。。。。

参考文章链接:https://www.cnblogs.com/dolphin0520/p/3938991.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值