- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在使用 ExecutorCompletionService 中的示例代码,并将以下示例代码放在一起。 solve() 中的代码按预期工作并打印
1<br/>
solve2() 中的代码不会打印任何内容,而且实际上永远不会退出。 ecs 是在将作业提交到 ExecutionService 之前还是之后构建并不重要。
2<br/>
3<br/>
4<br/>
5<br/>
是否无法将 CompletionService 构造与 FutureTasks 一起使用?我已经重写了我的生产代码以直接 get() FutureTask 的结果,而不是尝试从 ExecutorCompletionService 中 get() 它们,但它(当前)导致了一些看起来困惑的东西。简而言之,下面的solve2有什么问题?谢谢。
import java.util.ArrayList;
import java.util.Collection;
import java.util.concurrent.Callable;
import java.util.concurrent.CompletionService;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Executor;
import java.util.concurrent.ExecutorCompletionService;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.FutureTask;
public class sample {
public static class stringCallable implements Callable<String>{
String mstring;
stringCallable(String s) {mstring = s;}
@Override
public String call() throws Exception {
// TODO Auto-generated method stub
return mstring;
}
};
public static void main(String[] args) {
// TODO Auto-generated method stub
ArrayList<Callable<String>> list = new ArrayList<Callable<String>>();
ExecutorService es = Executors.newFixedThreadPool(1);
Executor e = Executors.newSingleThreadExecutor();
list.add(new stringCallable("1"));
list.add(new stringCallable("2"));
list.add(new stringCallable("3"));
list.add(new stringCallable("4"));
list.add(new stringCallable("5"));
try {
solve(e, list);
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (ExecutionException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
System.out.println ("Starting Solver 2");
try {
solve2(es, list);
} catch (InterruptedException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
} catch (ExecutionException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
static void solve(Executor e, Collection<Callable<String>> solvers)throws InterruptedException, ExecutionException {
CompletionService<String> ecs = new ExecutorCompletionService<String>(e);
for (Callable<String> s : solvers)
ecs.submit(s);
int n = solvers.size();
for (int i = 0; i < n; ++i) {
String r = ecs.take().get();
if (r != null)
use(r);
}
}
static void solve2(ExecutorService e, Collection<Callable<String>> solvers)throws InterruptedException, ExecutionException {
for (Callable<String> s : solvers){
FutureTask<String> f = new FutureTask<String>(s);
e.submit(f);
}
CompletionService<String> ecs = new ExecutorCompletionService<String>(e);
int n = solvers.size();
for (int i = 0; i < n; ++i) {
String r = ecs.take().get();
if (r != null)
use(r);
}
}
private static void use(String r) {
System.out.println (r);
}
}
最佳答案
在 solve2
,当您创建ExecutorCompletionService
时使用现有的ExecutorService
,它提交的任务会被包装器忽略,因为它使用单独的 LinkedBlockingQueue
。提交的任务不会被继承。因此,当您执行 ecs.take().get();
时,您的代码会阻塞。因为ExecutorCompletionService
本身没有任何已提交的任务。
此外,您不需要专门创建 FutureTask 来提交到 ExecutorCompletionService
。这些 future 任务已在内部为您创建。这就是为什么你会得到 Future<String>
调用ecs.take();
时.
鉴于此,您的solve2
功能完全没用。您已经在 solve1
中正确执行了此操作。 .
关于java - Callable 与 Runnable 中使用 "ExecutorCompletionService"的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1888449/
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 8 年前。 Improve th
我想知道如果我们有一个引用 const 的函数参数会发生什么功能如下图。 版本 1 int anotherFunc() { std::cout<<"inside anotherFunc"<
我正在尝试运行YOLOv8重新训练的对象检测测试,但我一直收到此错误。。我已经试过安装gnu-cobol和更新西芹了,还有其他想法吗?谢谢
我做了一个静态类方法(这里称为“函数”)f需要一个列表 Callable小号: import java.util.concurrent.*; import java.util.*; class A {
以下是我的类定义: class logline: def __init__(self,t,cmp,msg): self.t = t self.cmp = cmp
我正在用 dart 做一个小实验,我找不到一种方法来确定一个变量是否是“可调用的”,而无需显式检查每种类型(字符串、整数、 bool 等),并猜测它是否是可调用的,如果没有的话那些。我还尝试了一个 t
我大量使用来自 python 3 的 python 类型支持。 最近我试图将一个函数作为参数传递,但我没有找到使用 kwargs 的任何帮助。在 typing.Callable签名。 请检查下面的代码
每当我运行实现可调用的程序时,我都会以顺序形式获得输出。 就像,这是我的程序: package com.handson; import java.util.concurrent.ArrayBlocki
我编写了一个注释(在Spring Boot应用程序中)并尝试将其应用到Callable的call()方法上,但它不起作用,但另一方面,当应用于普通方法时(请参阅下面的代码),它有效,这一直困扰着我,你
我试图将对象列表拆分为较小的子列表,并在不同的线程上单独处理它们。所以我有以下代码: List instances = xmlInstance.readInstancesFromXml
我想我可以用 std.traits.functionAttributes 来做到这一点,但它不支持 static。对于任何类型的可调用对象(包含 opCall 的结构),我如何判断该可调用对象是否使用
我是新来的,如果我把这个放到错误的主题中,很抱歉? 我的问题: class TaskEol implements Callable> { ArrayList coordinates =
我有一些代码可以从目录中的多个 JAR 动态加载类。因为 JAR 中的代码是不受信任的,所以我希望通过对它们进行“沙盒处理”来保护主应用程序免受编码不良或恶意动态类的影响。我想做的一件事是“时间盒”不
这个问题在这里已经有了答案: Overriding special methods on an instance (5 个答案) 关闭 9 年前。 我有以下代码 import numpy as np
我正在尝试制作一个类似于 https://github.com/ElgarL/TownyChat/blob/master/src/com/palmergames/bukkit/TownyChat/To
有人可以解释为什么要继承未参数化和参数化的Callable: from typing import Callable from typing import NoReturn from typing i
我有一个任务要以固定速率运行。但是,我还需要每次执行后的任务结果。这是我尝试过的: 任务 class ScheduledWork implements Callable { public St
给定一个实例 x的 Callable , 我怎样才能运行 x在一个单独的进程中,以便我可以重定向进程的标准输入和输出?例如,有没有办法构建一个 Process来自Callable ?有没有标准Exec
我有以下可调用对象: public class Worker implements Callable{ @Override public Boolean call(){ boo
现在很清楚了what a metaclass is ,有一个相关的概念,我一直在使用,但不知道它的真正含义。 我想每个人都犯了一次括号错误,导致“对象不可调用”异常。更何况,使用 __init__ 和
我是一名优秀的程序员,十分优秀!