一尘不染

获取线程的输出

java

您认为获得线程工作结果的最佳方法是什么?想象一个执行一些计算的线程,您如何警告主程序计算完成?

您可以每隔X毫秒轮询某个称为“作业完成”的公共变量或其他方式,但是随后您将在结果可用时才收到结果……主代码将浪费时间等待它们。另一方面,如果使用较低的X,则轮询将浪费CPU太多次。

因此,您如何做才能知道线程或某些线程已经完成了工作?

抱歉,如果它看起来与此其他问题相似,我想这可能是 eben
答案的原因。我的意思是运行很多线程,并且知道所有线程何时完成,而无需轮询它们。

我在考虑使用一批线程在多个CPU之间共享CPU负载方面的更多思考,并且知道一批何时完成。我想可以用 Future 的对象完成它,但是阻塞 _ get_ 方法看起来很像一个隐藏的锁,而不是我喜欢的东西。

感谢大家的支持。虽然我也很喜欢通过回答 _ 埃里克森 ,我觉得 _ SAUA 的最完整的,和一个我会在自己的代码中使用。


阅读 198

收藏
2020-12-03

共1个答案

一尘不染

除非绝对需要强大的功能和灵活性,否则请不要使用诸如线程之类的低级构造。

您可以使用ExecutorService(例如ThreadPoolExecutor)提交()
Callables。这将返回一个Future对象。

使用该Future对象,您可以轻松地检查它是否完成并获得结果(get()如果尚未完成,则包括阻塞)。

这些构造将大大简化最常见的线程操作。

我想澄清有关阻塞的信息get()

这个想法是,您想运行一些任务(这些任务Callable)来完成某些工作(计算,资源访问等),而这些工作 现在
不需要结果。您可以仅依靠来在Executor需要时运行您的代码(如果是,ThreadPoolExecutor则只要有可用的线程就可以运行)。然后在某个时间点,您可能
需要
计算结果才能继续。此时,您应该致电get()。如果该任务已经在该点运行,则将get()立即返回该值。如果任务未完成,则get()呼叫将等待,直到任务完成。这通常是理想的,因为无论如何您都无法完成任务。

当您不需要该值继续时,但是想知道它是否已经可用时(可以在UI中显示某些内容),那么您可以轻松地调用,isDone()并且仅get()在返回时调用true)。

2020-12-03