我有一个在给定时间每天运行的线程。 它给了我这个错误信息:
2014-05-21 03:57:06 [关键] [AlertMgr]:维护:
java.lang.IllegalArgumentException:超时值为负数 at java.lang.Thread.sleep(Native Method) 在 com.orca.pf.tc50.managerutilities.maintenance.MaintenanceManager.backgroundProcess(未知 资源) 在 com.orca.pf.tc50.managerutilities.maintenance.MaintenanceManager.access $ 000(未知 资源) 在 com.orca.pf.tc50.managerutilities.maintenance.MaintenanceManager $ 1.run(未知 资源) 在java.lang.Thread.run(Thread.java:745)。
你知道是什么原因引起的。
由于
private void backgroundProcess()
{
Calendar cal;
cal = Calendar.getInstance();
log.addHelpField("AlertMgr");
/*
* Synchronise le calendrier a 3:00AM
*/
cal.set(Calendar.MINUTE, 0);
cal.set(Calendar.SECOND, 0);
cal.set(Calendar.MILLISECOND, 0);
if (cal.get(Calendar.HOUR_OF_DAY) > HOUR_START)
{
/*
* wait till tomorrow
*/
cal.set(Calendar.HOUR_OF_DAY, HOUR_START);
cal.add(Calendar.DAY_OF_YEAR, 1);
}
else
{
cal.set(Calendar.HOUR_OF_DAY, HOUR_START);
}
do
{
try
{
/*
* Calculate the time to wait
*/
long timeToWait = cal.getTimeInMillis() - System.currentTimeMillis();
Thread.sleep(timeToWait);
processAllEntries();
/*
* wait for tomorrow
*/
cal.add(Calendar.DAY_OF_YEAR, 1);
/*
* Clear
*/
Thread.interrupted();
}
catch(InterruptedException i)
{
Thread.currentThread().interrupt();
}
catch(Exception ex)
{
log.addException(LogLevel.CRITICAL, "maintenance", ex);
}
}
while(!th.isInterrupted());
}
答案 0 :(得分:1)
我向您推荐,而不是使用Thread.sleep()尝试查看Java Timer class。它将简化您每x小时调度作业的任务。它将节省您计算睡眠时间以安排下一个任务的工作量。该课程让您专注于业务逻辑,并负责安排任务。