java的并发包提供了好多 方便的方法,此处主要实验shutdown(),shutdownNow(),awaitTermination();
shutdown()指的是执行已经提交的任务,但是不接受新的任务。
shutdownNow()指的是停止正在执行的所有任务,暂停处理正在等待的任务,返回等待执行的任务列表。
awaitTermination(long timeout,TimeUnit tu)是阻塞等待,等待任务的时间为(timeout),如果超过这个时间就执行下面代码,并返回值,不会影响多线程的执行。
本实例代码在等待6s后,终止了所有线程的执行。算是 超时等待的一个实现吧。
public class TestT {
public static void main(String[] args) {
TestT t = new TestT();
ExecutorService executor = Executors.newFixedThreadPool(10);
for(int i=0;i<10;i++){
executor.execute(t.new TestConcurrent());
}
executor.shutdown();
try {
executor.awaitTermination(6, TimeUnit.SECONDS);
System.out.println("我等了6s");
executor.shutdownNow();
} catch (InterruptedException e) {
// TODO Auto-generated catch block
System.out.println("i am interrupted");
e.printStackTrace();
}
}
public class TestConcurrent implements Runnable {
public void test(){}
@Override
public void run() {
// TODO Auto-generated method stub
try {
Thread.sleep(1000*10);
System.out.println("i am "+ Thread.currentThread().getName());
} catch (InterruptedException e) {
// TODO Auto-generated catch block
System.out.println(" 被终止了");
}
}
}
}