黑马程序员技术交流社区

标题: 关于线程池的问题,求分析程序运行结果 [打印本页]

作者: 任传敏    时间: 2012-7-9 10:52
标题: 关于线程池的问题,求分析程序运行结果
创建一3个线程的线程池,为其分配5个任务,预期结果应该是:三个线程先为0、1、2号任务服务,完成后再有两个线程为其余两个任务服务。可是运行结果确不是这样,程序如下:
package thread;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class ThreadPoolTest {

        /**
         * @param args
         */
        public static void main(String[] args) {
                // TODO Auto-generated method stub
                ExecutorService executorService = Executors.newFixedThreadPool(3);
                for (int i = 0; i < 5; i++) {
                        final int task = i;
                        executorService.execute(new Runnable() {

                                @Override
                                public void run() {
                                        for (int j = 0; j < 5; j++) {
                                                /*try {
                                                        Thread.sleep(20);
                                                } catch (InterruptedException e) {
                                                        // TODO Auto-generated catch block
                                                        e.printStackTrace();
                                                }*/
                                                System.out.println(Thread.currentThread().getName()
                                                                + " is running loop of " + j + " of task "
                                                                + task);
                                        }
                                }
                        });
                }
                System.out.println("5 task has put in!");
                executorService.shutdown();
        }
}
后来加上被注释的那几行,在运行结果才跟预期的一样!现在我不明白为什么要休眠20毫秒,请高手给解释一下!谢谢!




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2