之前一个应用在新的机型上出现闪退的问题,还是必现,复现了下,看到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);
}
这个问题是系统的问题,时间没有校对正确。。。。