- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我尝试使用 Java 的 FutureTask
、Future
、Runnable
、Callable
和 ExecutorService
类型。
构建这些构建 block 的最佳做法是什么?
鉴于我有多个 FutureTask
,并且我想按顺序执行它们。
当然,我可以创建另一个 FutureTask,它按顺序为每个子任务提交/等待结果,但我想避免阻塞调用。
另一种选择是让这些子任务在完成时调用回调,并在回调中安排下一个任务。但是沿着这条路,我如何创建一个适当的外部 FutureTask 对象,它也可以处理子任务中的异常而不产生那么多的样板文件?
我在这里错过了什么吗?
最佳答案
非常重要的事情,虽然通常不会在教程中描述:
要在 ExecutorService 上执行的 Runnable 不应阻塞
。这是因为每次阻塞都会关闭一个工作线程,如果 ExecutorService 的工作线程数有限,则存在陷入死锁(线程饥饿)的风险,如果 ExecutorService 的工作线程数不受限制,则存在死锁的风险内存不足。任务中的阻塞操作只会破坏 ExecutorService 的所有优势,因此请仅在普通线程上使用阻塞操作。
FutureTask.get()
是阻塞操作,因此可以在普通线程上使用,而不是在 ExecutorService 任务中使用。也就是说,它不能作为构建 block ,而只是将执行结果传递给主线程。
从任务构建执行的正确方法是在下一个任务的所有输入数据都准备好时开始下一个任务,这样任务就不必阻塞等待输入数据。所以你需要一种存储中间结果并在所有参数到达时启动新任务的门。因此,任务不会显式地启动其他任务。因此,门由用于参数的输入套接字和用于计算参数的 Runnable 组成,可以被视为在 ExcutorServices 上进行计算的正确构建 block 。
这种方法称为数据流或工作流(如果不能动态创建门)。
像 Akka 这样的 Actor 框架使用这种方法,但在 actor 是一个具有单一输入套接字的门这一事实中受到限制。
我写了一个真正的数据流库,发布于 https://github.com/rfqu/df4j .
关于Java 的 FutureTask 可组合性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14704812/
基本上我有以下代码片段, (let [task (FutureTask. fn) thr (Thread. task)] (.start thr) ;;wait for signa
我正在尝试将请求发送到服务器...直到请求没有响应我想执行一个打印整数的循环..问题是我的循环一直持续下去,如果我执行它直到 100 它会打印 100 个值并且如果直到 1000,它就会打印 1000
我正在创建一个 Java 应用程序。启动时,我的应用程序将下载所有必需的文件。我的应用程序将解析 XML 文件并从 XML 文件的 URL 下载文件。我希望我的应用程序“一步一步”下载文件,所以我使用
在 FutureTask.get 的 CancellationException 异常之后访问底层 Callable 的首选方法是什么? 我有以下代码- public class Ping imple
假设我用 Java 做了一些事情,比如: RemoteResponse response = null; try { FutureTask task new FutureTask(....);
我正在制作一些虚拟程序来了解这个 Java 类。我的定时任务调用了一个什么也不做的任务,在中断它之前给它 3 秒的时间。这是代码: FutureTask task = new FutureTask<>
new Thread(new Runnable() { public void run() { .............
这是一个非常简单的代码: FutureTask task = new FutureTask<>(new Callable(){ @Overrid
我创建了以下 FutureTask 方法来异步运行方法。 public FutureTask SendAggregateEventAsync(final com.Company.Pro
我已经实现了并发实践中描述的自定义取消逻辑。 Encapsulating nonstandard cancellation in a task with newTaskFor . 这很好用,我可以调用
我检查了 Oracle Java API,它提供了一些信息 FutureTask.isDone() 但我需要检查任务是否已完成或因任何错误而终止。isDone() 方法即使完成/终止也会返回。但我需要
我目前正试图了解如何 FutureTask.cancel(true)正在工作,这是官方文档的相关部分 If the task has already started, then the mayInte
我尝试实现一个内部方法,以便在新线程中执行以下代码 MyPojo result = null; final MyPojo result2 = result; FutureTask runnableTa
下面的代码无法编译(JDK 1.8.0_40),我无法理解为什么。 public abstract class BackgroundThread { private final Executo
我已经在网上搜索了一个星期了,但没有像这样的帖子 How do I get FutureTask to return after TimeoutException?似乎回答了我的问题。我从我的代码中提
我想为昂贵的路径查找任务设置一个 FutureTask。所以我创建了这个 Callable 类。 public class GetPath implements Callable> { pri
考虑在 Callable 实例中进行长时间运行的计算。 并且考虑到这个计算的结果可以有一定的精度取决于计算时间,即:如果任务将被取消,那么它应该返回取消之前到目前为止计算的内容(例如,我们有一个计算无
我遇到了这个令人沮丧的问题:我试图查看下面的代码中是否抛出 TimeoutException,但这种情况从未发生过。它总是打印当前时间 5 次并完成。 class MyTask1 implements
在我的可调用代码中,我使用信号通知向另一个线程通知多个结束行为。 Callable 对象与 Executor 中的 FutureTasks 一起排队。排队后也可能被取消。 现在,我的问题是,我至少依赖
我有一个应用程序,它定期提交要在专用线程中执行的任务。这些任务是 FutureTask并且线程只不过是一个无限循环,它在作业进入队列时执行作业,如果为空则进入 hibernate 状态。 有时我需要等
我是一名优秀的程序员,十分优秀!