Ant任务在main方法中正常,但在Ant执行期间在确定的行之后停止

时间:2015-04-08 10:48:20

标签: java ant maven-ant-tasks

有谁知道,为什么这样的蚂蚁任务:

public void execute() {
    Timer timer = new Timer();
    TimerTask action = new TimerTask() {
        @SuppressWarnings("ResultOfMethodCallIgnored")
        public void run() {
            String urlsForCheckPath = arachniBinPath + "urls.txt";
            List<String> urlsForCheck;
            try {
                urlsForCheck = FileUtils.readLines(new File(urlsForCheckPath));
                if (urlsForCheck != null) {
                    for (String urlForCheck : urlsForCheck) {
                        new File(arachniLogPath).delete();
                        clearTemporary(urlForCheck);//if something remains after exceptions
                        logger.info(urlForCheck + " previous log and possibly remaining temporary files deleted.");
                        checkURL(urlForCheck);
                        urlForCheck = urlForCheck.replace("/", "-");
                        convertAndSend(urlForCheck);
                        clearTemporary(urlForCheck);
                        logger.info(urlForCheck + " temporary files deleted.");
                    }
                }
            } catch (Exception e) {
                log(e);
            }
        }
    };
    timer.schedule(action, delayBeforeStart);
}

在main方法中正常,但在

之后停止
 logger.info(urlForCheck + " previous log and possibly remaining temporary files deleted.");

在通过ant执行期间没有例外?如何解决?

1 个答案:

答案 0 :(得分:1)

我认为你应该阅读这个答案。 Java: Wait for TimerTask to complete before continuing execution

小例子:

protected final Timer timer = new Timer();

public void execute() {
   CountDownLatch latch = new CountDownLatch(1);
   timer.schedule(new TimerTask() {
       public void run() {
       }
   }, delayBeforeStart);
   try {
       latch.await();
   } catch (InterruptedException e) {
       log(e);
   }
   timer.cancel();
}