线程池

package com.threadpool;

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

/*
 * 线程池:线程池内每一个线程代码执行完后不会死亡,而是再次回到线程池内成为空闲状态,等待下一个对象来使用
 *   如何实现线程的代码呢?
 *     1.创建线程池对象,控制要创建几个线程对象
 *     2.这种线程池的线程可以执行:
 *        Runnable对象或Callable对象代表的线程
 *     3.Future submit(Runnable runable)
 *        Future submit(Callable callable)
 *     4.结束线程池
 *       shutdown():执行完以前提交的任务,但不再接收新任务
 *       
 *     jdk1.5以后才有的
 */
public class ThreadPoolDemo {
    public static void main(String[] args) {
       //创建线程池对象,并指定控制要创建几个线程对象
       ExecutorService pool = Executors.newFixedThreadPool(3);    
       //执行线程
       pool.submit(new MyRunnable());
       pool.submit(new MyRunnable());
       pool.submit(new MyRunnable());
       
       pool.shutdown();
    }      
}
       //可以简单理解为Callable是基于线程池才能使用的

      //创建线程池对象,管理的线程个数不限
        ExecutorService pool = Executors.newCachedThreadPool();
      //创建线程池对象,管理指定线程个数
        ExecutorService es=Executors.newFixedThreadPool(1);

     /*
      * 线程池的核心类和接口在java.util.concurrent包下
      */


 

posted @ 2017-09-01 15:39  scwyfy  阅读(111)  评论(0编辑  收藏  举报