ExecutorService pool = Executors.newFixedThreadPool(2); //创建一个能放两个线程的池子
Thread t1 = new Thread();
Thread t2 = new Thread();
pool.execute(t1);
pool.execute(t2);//这是异步的
如果要想知道,t1和t2,都走完了。
需要这么写
pool.shutdown();//先关闭线程池,不会影响已运行的线程
while (true) {
if (pool.isTerminated()) {
//所有任务完成
break;
}
Thread.sleep(200);
}
还有一种写法
List<Future> list=new ArrayList<Future>();
list.add(exe.submit(new Runnable() {
@Override
public void run() {
}
}));
for(int i=0;i<list.size();i++){
try {
list.get(i).get();
} catch (ExecutionException e) {
e.printStackTrace();
}
}
这种方法会阻碍主线程