Java.lang.IllegalArgumentException:超时值为负数

时间:2014-05-22 16:25:34

标签: java multithreading timeout illegalargumentexception

我有一个在给定时间每天运行的线程。 它给了我这个错误信息:

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());
}

1 个答案:

答案 0 :(得分:1)

我向您推荐,而不是使用Thread.sleep()尝试查看Java Timer class。它将简化您每x小时调度作业的任务。它将节省您计算睡眠时间以安排下一个任务的工作量。该课程让您专注于业务逻辑,并负责安排任务。