浏览 3789 次
精华帖 (0) :: 良好帖 (0) :: 新手帖 (1) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2013-10-26
package ThreadPool; public class NewThread implements Runnable { @Override public void run() { int x = 0; while (x < 100) { try { Thread.sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } x++; } System.out.println(Thread.currentThread().getName() + ":" + x); } } /*Main方法*/ package ThreadPool; import java.util.concurrent.ExecutorService; import java.util.concurrent.Executors; import java.util.concurrent.TimeUnit; public class Main { public static void main(String[] args) { long start = System.currentTimeMillis(); ExecutorService pool = Executors.newFixedThreadPool(1000);// 新起一个1000个线程的线程池 for (int x = 0; x < 800; x++) {// 给这个线程池指定80个进程 pool.execute(new Thread(new NewThread())); } /* * shutDown() 当线程池调用该方法时,线程池的状态则立刻变成SHUTDOWN状态。此时,则不能再往线程池中添加任何任务,否则 * 将会抛出RejectedExecutionException异常。但是,此时线程池不会立刻退出, 直到添加到线程池中的任务都已经 * 处理完成,才会退出。 */ pool.shutdown(); try { /* * 等待10秒当线程池的工作队列中的所有任务执行完 毕,就返回true,如果10秒后还没完,则false,下面的 * 代码是相当于超时了,执行强制关闭 */ boolean notTimeOut = pool.awaitTermination(10, TimeUnit.SECONDS); System.out.println(System.currentTimeMillis() - start);// 运行至此 if (!notTimeOut) { System.out.println("TimeOut!!"); /* * shutdownNow() 根据JDK文档描述,大致意思是:执行该方法,线程池的状态立刻变成STOP状态, * 并试图停止所有正在执行的线程,不再处理还在池队列中等待的任务,当然,它会返回那些未执行的 任务。 */ pool.shutdownNow(); } } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } System.out.println(System.currentTimeMillis() - start);// 所有线程结束 } } 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2013-10-27
先把 InterruptedException 处理好
|
|
返回顶楼 | |
发表时间:2013-10-30
InterruptedException
|
|
返回顶楼 | |