1

我有几个线程运行几乎无限的时间和迭代次数。当找到最佳解决方案时,迭代计数将重置为 0。设置最大迭代次数以防止无限循环。

当所有线程都达到最大迭代次数时,我使用 countdownlatch 停止进程。换句话说,当一个线程达到最大迭代次数时,它使用notifyThreadStop()通知我的主线程,当所有线程停止时,触发 countdown()。

注意:我的线程在 FixedThreadPool ExecutorService 中运行。

我想添加一个 maxTime 锁存器。所以我做的是以下

List<Runnable> r = .... //(contains all my runnables)
myExecutorService.invokeAll(r);

if(maxtime > 0){
    mylatch.await(maxTime,TimeUnit.Seconds);
    (1)
    do stuff...
    exit;
}
else{
    mylatch.await();
    myExecutorService.shutdownNow();
    do stuff...
    exit;
}

现在,我知道如果倒计时触发了闩锁,这意味着所有线程都已停止,因此我可以关闭我的 ExecutorService。

当达到最大时间时,情况并非如此。所以在(1)中,我想遍历我所有的跑步者,以文明的方式终止他们:-)。为此,我定义了一个函数 requestTermination(),简单地说,就是在我的 runnables 中将迭代计数器设置为 MaxIterationCount。

所以(1)会变成

    for(Runnable runner: r){
        if(r.getIsRunning()){r.requestTermination();}
    }
    (2)

现在,我需要再次等待,直到所有线程都真正停止,然后我才能继续......嗯,我只是想我可以有一个额外的锁存器并使用它。

所以(2)会变成

    mylatch2.await();
    myExecutorService.shutdownNow();

当然,我的函数notifyThreadStop()需要对其进行修改,并且需要一个标志告诉它在 mylatch2 上而不是 mylatch 上执行 countdown()。

我想我刚刚回答了我的问题,但是既然所有这些都已经写完了,我将把它留在这里供其他人参考。

现在的问题是:有更好的方法来处理这个问题吗?(1) 或 (2) 中的 shutdownNow() 是唯一需要的吗?知道我的线程必须在退出之前关闭它们自己的日志文件并关闭它们内部的 Callable thread*ss*。

4

2 回答 2

0

如果您使用 shutdownNow() 和 awaitTernimation() 这将中断所有正在运行的任务并等待它们完成。

如果任务可以中断并在中断时正确关闭所有资源,则应该没有问题。(如果有问题,这是你的任务代码中的一个错误,你应该修复它)

于 2011-02-04T14:20:28.863 回答
0

我想我刚刚回答了我的问题,但既然所有这些都已经写好了

您确实做到了:-) 如果要添加一件事是您应该小心 RuntimeExceptions,否则,您的 shutdownNow() 可能永远不会被调用。但你已经知道了,对吧?

于 2011-02-04T14:20:39.717 回答