krs*_*888 4 java multithreading executorservice java.util.concurrent threadpool
我试图了解运行时如何创建未来对象executorService.submit(Callable);
例如,假设我创建了一个线程池,在其中传递可调用的实现
class FactorialCalculator implements Callable<Long> {
private int number;
public FactorialCalculator(int number) {
this.number = number;
}
@Override
public Long call() throws Exception {
return (number*number);
}
}
Run Code Online (Sandbox Code Playgroud)
我想返回 future 对象,这样我就可以从调用函数中获取返回值。我的自定义线程池如下所示
class MyThreadPool implements java.util.concurrent.Executor
{
private final java.util.concurrent.BlockingQueue<Callable> queue;
public MyThreadPool(int numThreads) {
queue = new java.util.concurrent.LinkedBlockingQueue<>();
for (int i=0 ; i<numThreads ; i++) {
new Thread(new Runnable(){
@Override
public void run() {
while(true) {
queue.take().call();
}
}
}).start();
}
}
@Override
public void submit(Callable command) {
queue.put(command);
}
}
Run Code Online (Sandbox Code Playgroud)
现在如果我这样做
MyThreadPool mypool = new MyThreadPool(10);
mypool.submit(new FactorialCalculator(10));
Run Code Online (Sandbox Code Playgroud)
我想提交方法以返回 future,这样我就可以检查线程是否已完成执行的返回值。如何返回未来的对象。
最简单的方法是将可调用对象包装在 FutureTask 中:
@Override
public <T> Future<T> submit(Callable<T> callable) {
FutureTask<T> future = new FutureTask(callable);
queue.put(future);
return future;
}
Run Code Online (Sandbox Code Playgroud)
当然,更简单的解决方案是使用它,Executors.newFixedThreadPool而不是自己重新实现它。
| 归档时间: |
|
| 查看次数: |
1664 次 |
| 最近记录: |