用于基本任务的Java 8 Concurrency最简单的规范形式
作者:互联网
我有两个问题:
1.在Java 8中将Callable作为任务运行,捕获和处理结果的最简单的规范形式是什么?
2.在下面的示例中,在所有任务完成之前,保持主进程打开的最佳/最简单/最清晰的方法是什么?
这是我到目前为止的例子 – 这是Java 8中最好的方法还是有更基本的东西?
import java.util.*;
import java.util.concurrent.*;
import java.util.function.*;
public class SimpleTask implements Supplier<String> {
private SplittableRandom rand = new SplittableRandom();
final int id;
SimpleTask(int id) { this.id = id; }
@Override
public String get() {
try {
TimeUnit.MILLISECONDS.sleep(rand.nextInt(50, 300));
} catch(InterruptedException e) {
System.err.println("Interrupted");
}
return "Completed " + id + " on " +
Thread.currentThread().getName();
}
public static void main(String[] args) throws Exception {
for(int i = 0; i < 10; i++)
CompletableFuture.supplyAsync(new SimpleTask(i))
.thenAccept(System.out::println);
System.in.read(); // Or else program ends too soon
}
}
有没有更简单,更清晰的Java-8方法呢?我如何消除System.in.read()以支持更好的方法?
解决方法:
等待完成多个CompletableFuture实例的规范方法是通过CompletableFuture.allOf
创建一个新的,取决于所有这些实例.您可以使用这个新的未来等待其完成或安排新的后续操作,就像使用任何其他CompletableFuture一样:
CompletableFuture.allOf(
IntStream.range(0,10).mapToObj(SimpleTask::new)
.map(s -> CompletableFuture.supplyAsync(s).thenAccept(System.out::println))
.toArray(CompletableFuture<?>[]::new)
).join();
当然,如果您放弃为每个任务分配唯一ID,它总是变得更简单.由于您的第一个问题是关于Callable,我将演示如何通过ExecutorService轻松地将多个类似的任务作为Callables提交:
ExecutorService pool = Executors.newCachedThreadPool();
pool.invokeAll(Collections.nCopies(10, () -> {
LockSupport.parkNanos(TimeUnit.MILLISECONDS.toNanos(
ThreadLocalRandom.current().nextInt(50, 300)));
final String s = "Completed on "+Thread.currentThread().getName();
System.out.println(s);
return s;
}));
pool.shutdown();
Executors.newCachedThreadPool()返回的执行程序服务是非共享的,即使您忘记调用shutDown()也不会保持活动状态,但在所有线程终止之前最多可能需要一分钟.
因为你的第一个问题字面上是:“在Java 8中运行Callable作为任务,捕获和处理结果的最简单的规范形式是什么?”,答案可能是最简单的形式仍然是直接调用它的call()方法,例如
Callable<String> c = () -> {
LockSupport.parkNanos(TimeUnit.MILLISECONDS.toNanos(
ThreadLocalRandom.current().nextInt(50, 300)));
return "Completed on "+Thread.currentThread().getName();
};
String result = c.call();
System.out.println(result);
没有简单的方法……
标签:completable-future,java,java-8,concurrency 来源: https://codeday.me/bug/20190722/1503166.html