类GetSumCallable实现接口:
import java.util.concurrent.Callable;
public class GetSumCallable implements Callable<Integer> {
public Integer call(){
int sum=0;
for(int i=0;i<=100;i++)
sum=sum+i;
return sum;
}
}
类GetSumCallable2实现接口:
import java.util.concurrent.Callable;
public class GetSumCallable2 implements Callable<Integer> {
public Integer call(){
int sum=0;
for(int i=0;i<=200;i++)
sum=sum+i;
return sum;
}
}
测试Demo类:
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
/*
* 使用多线程技术,求和(线程池)
* 两个线程,1个线程计算1+100;另一个线程计算1+200的和
* 多线程的异步计算
*/
public class ThreadPoolDemo {
public static void main(String[] args) throws Exception {
ExecutorService es=Executors.newFixedThreadPool(2);
Future<Integer>f=es.submit(new GetSumCallable());
int s1=f.get();
System.out.println(s1);
Future<Integer>f1=es.submit(new GetSumCallable2());
int s2=f1.get();
System.out.println(s2);
}
}