当前位置: 首页 > 面试题库 >

获取线程的输出

丁韬
2023-03-14
问题内容

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

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

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

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

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

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


问题答案:

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

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

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

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

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

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

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



 类似资料:
  • 问题内容: 我正在Android中编写一个活动,用户可以在其中修改SQL数据库。用户界面由一个EditText(用户在其中输入名称)和一个Seekbar(用户在其中输入用户的吸引力)组成。在下面有很多按钮:添加,编辑,查看,删除。 当用户单击“编辑”按钮时,将显示一个输入对话框,要求用户输入记录号。完成后,将加载该记录。 我遇到的问题是,将显示输入对话框,并且当用户输入记录号时,其余的编辑方法将继

  • 问题内容: 我有一个Java应用程序,其中创建了一些线程(通过)。通过使用,我可以看到它们具有不同的线程ID(LWP列),我想从Java应用程序中获取这些ID。 在我发现的与此主题相关的大多数文章中,解决方案是使用。 但是,使用该方法可以为我提供主线程的PID(即使我从其中一个线程调用它),因此它并不能真正解决我的问题。 有什么方法可以获取应用程序创建的每个线程的线程ID ? 是否可以使用JNI完

  • 问题内容: 我有一个固定的线程池,我可以将任务提交给该线程池(限制为 5个 线程)。如何找出这 5个 线程中的哪一个执行我的任务(例如“第3 个 线程中的第3 个 线程正在执行此任务”)? 问题答案: 使用:

  • 问题内容: 我有一个多线程应用程序,并且通过属性为每个线程分配了唯一的名称。现在,我希望功能可以使用相应的名称直接访问线程。 类似于以下功能的东西: 上面的函数检查所有正在运行的线程,然后从正在运行的线程集中返回所需的线程。也许我想要的线程被中断了,那么上面的功能将无法正常工作。关于如何整合该功能的任何想法? 问题答案: 您可以使用ThreadGroup查找所有 活动 线程: 获取当前线程的组 通

  • 问题内容: 在大多数应用程序服务器上,J2EE Ejb规范禁止“手动”创建线程,因为这些资源应由服务器管理。 但是有什么方法可以从Tomcat,Glassfish,Jboss等获取线程;因此访问他们的ThreadPool? 问题答案: 您可以使用commonj WorkManager 。IBM和BEA提出了一项建议,以提供一种完成此任务的标准方法(访问容器管理的线程)。 尽管它没有包含在实际规范中