package thread;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
public class FutureTaskDemo {
public static void main(String[] args) throws InterruptedException, ExecutionException {
long sum = 0;
ExecutorService exec = Executors.newCachedThreadPool();
List<Callable<Long>> callList = new ArrayList<Callable<Long>>();
callList.add(new Callable<Long>(){
public Long call(){
long sum = 0;
for(long i=0;i<50;i++){
sum+=i;
}
return sum;
}
});
callList.add(new Callable<Long>(){
public Long call(){
long sum = 0;
for(long i=50;i<=100;i++){
sum+=i;
}
return sum;
}
});
List<Future<Long>> futureList=exec.invokeAll(callList);
for(Future<Long> future:futureList){
sum+=future.get();
}
System.out.println(sum);
exec.shutdown();
}
}
FutureTask的一个简单Demo
并发计算示例
最新推荐文章于 2024-09-30 18:29:48 发布
本文介绍了一个使用Java实现的简单并发计算示例。该示例通过创建两个Callable任务来计算0到100之间的整数之和,并利用ExecutorService进行调度执行。最后将两个Future对象的结果相加得到最终求和结果。
394

被折叠的 条评论
为什么被折叠?



