线程池,--其实就是一个
容纳多个线程的容器
,其中的线程可以反复使用,省去了频繁创建线程对象的操作
,--无需反复创建线程而消耗过多资源。
创建销毁线程是一个非常消耗性能的。

我们详细的解释一下为什么要使用线程池?
在java中,如果每个请求到达就创建一个新线程,开销是相当大的。--在实际使用中,
创建和销毁线程花费的时间和消耗的系统资源都相当大--,甚至可能要比在处理实际的用户请求的时间和资源要多的多。--除了创建和销毁线程的开销之外,活动的线程也需要消耗系统资源。--
如果在一个jvm里创建太多的线程,可能会使系统由于过度消耗内存或“切换过度”而导致系统资源不足。为了防止资源不足,--需要采取一些办法来限制任何给定时刻处理的请求数目,尽可能减少创建和销毁线程的次数,特别是一些资源耗费比较大的线程的创建和销毁,尽量利用已有对象来进行服务。
数据库连接池--(原理和线程池是一样的)--:C3P0
--传统JDBC的操作,每次创建和销毁连接都是非常消耗系统资源的两个过程,影响程序的运行效率!
--连接管理: 为了解决性能问题,可以使用连接池优化的程序,来共享链接Connection
预先创建一组连接,--放入到连接池中,用的时候每次取出一个; 用完后,放回;


Java里面线程池的顶级接口是 Executor,不过真正的线程池接口是
ExecutorService
, ExecutorService 的默认实现是 ThreadPoolExecutor;
普通类 Executors 里面调用的就是 ThreadPoolExecutor。
Executors:线程池创建工厂类
Executors 类提供工厂方法用来创建不同类型的线程池。比如: newSingleThreadExecutor() 创建一个只有一个线程的线程池,newFixedThreadPool(int numOfThreads)来创建固定线程数的线程池,newCachedThreadPool()可以根据需要创建新的线程,但如果已有线程是空闲的会重用已有线程。