线程池

1.JDK5新增了一个Executors工厂类来产生线程池,有如下几个方法

         public static ExecutorService newFixedThreadPool(int nThreads)

         public static ExecutorService newSingleThreadExecutor()

 

2. 这些方法的返回值是ExecutorService对象,该对象表示一个线程池,

           可以执行Runnable对象或者Callable对象代表的线程。

           它提供了如下方法

                  Future<?> submit(Runnable task)

                  <T> Future<T> submit(Callable<T> task)

 

3.使用步骤:

         1.创建线程池对象

         2.创建Runnable实例

         3.提交Runnable实例

         4.关闭线程池es.shutdown();

4.Runnable和Callable的区别

  Runnable的run方法没有返回值

  Callable的call方法有返回值,一般返回值也没用

 

案例演示:

public class Demo01 {
    public static void main(String[] args) {
        //案例:10个线程完成10个洗车任务
        /*for(int i = 0;i<10;i++){
            new Thread(){
                public void run() {
                    System.out.println("洗车任务 " + Thread.currentThread());
                };
            }.start();
        }*/
        
        //案例:5个线程完成10个洗车的任务
        //1.创建线程池
        ExecutorService es = Executors.newFixedThreadPool(5);
        
        //2.添加任务-方式一
        /*for(int i=0;i<10;i++){
            es.submit(new Runnable() {
                @Override
                public void run() {
                    System.out.println("洗车任务 " + Thread.currentThread());
                }
            });
        }*/
        
        //3.添加任务-方式二
        for(int i=0;i<10;i++){
            es.submit(new MyTask());
        }
        
    }
}

class MyTask implements Callable<Integer>{

    @Override
    public Integer call() throws Exception {
        System.out.println("洗车任务 " + Thread.currentThread());
        return 110;
    }
    
}

 

posted @ 2018-12-22 17:54  expworld  阅读(66)  评论(0编辑  收藏  举报