ScheduledExecutorService每次都开始较晚

时间:2011-05-17 15:22:07

标签: java timer scheduled-tasks

我正在处理一小段具有ScheduledExecutorService的代码。

为此,我有以下代码:

Calendar fileTimestamp = Calendar.getInstance(); fileTimestamp.setTime(fileObj.getDateToCopy());

ScheduledExecutorService fileDispatcher = Executors.newScheduledThreadPool(5);
CopyTask  copyTask = new CopyTask();
long schedulerTrigger = fileTimestamp.getTimeInMillis() -   Calendar.getInstance().getTimeInMillis();

System.out.println("***[MAIN-INFO]["+fileObj.getFile_id()+"] fileTimeStamp:"+fileTimestamp.getTime());

System.out.println("***[MAIN-INFO]["+fileObj.getFile_id()+"] now
            TimeStamp:"+Calendar.getInstance().getTime()); 
System.out.println("[MAIN-INFO]["+fileObj.getFile_id()+"]
             scheduledTrigger [hh:mm:ss]: 
             "+formatDateDiff(schedulerTrigger) );
ScheduledFuture<?>  result = fileDispatcher.schedule(copyTask,
             schedulerTrigger, TimeUnit.MILLISECONDS);

我们必须在达到时间戳时执行copyTask。 问题是copyTask执行得很晚:每次延迟大约3分钟。 下面是消息:

***[MAIN-INFO][401850] fileTimeStamp:Tue May 17 17:09:38 CEST 2011
***[MAIN-INFO][401850] now TimeStamp:Tue May 17 17:07:38 CEST 2011
[MAIN-INFO][401850] scheduledTrigger [hh:mm:ss]:  0:2:0 (120000 ms) 

正在运行的任务的消息:

[401850-INFO] Launch time:Tue May 17 17:09:38 CEST 2011
[401850-INFO] Current time:Tue May 17 17:12:04 CEST 2011
[401850-INFO] Start copying FILE_ID=401850
[401850-INFO] Copy file OK

目前我在CopyTask中有这段代码:

public void run() {   

   System.out.println("["+taskId+"-INFO] Current time:"+new Date());
}

我们可以看到启动时间(必须运行的作业的时间)与当前时间(执行作业的实时时间)不同。

有没有人知道为什么这么晚跑?

1 个答案:

答案 0 :(得分:0)

忘了它。 现在它似乎工作。我不知道为什么,因为我什么也没做。