简单说一下线程池

时间:2022-01-28 21:17:16

        线程池是用来方便创建多个线程的一个工具,当需要创建大量线程的时候,用Thread来创建线程已经不合适了,这时就可以使用线程池,通过线程池来控制创建线程。线程池的*接口是Executor,我们常用的接口是ExecutorService,该接口是Executor的子接口,创建线程池通过Executors工具类,常用的有两个线程池,newFixedThreadPool,newCachedThreadPool。如:ExectuorService executor = Executors.newFixedThreadPool(1);来创建,1表示同时只有一个线程是执行状态。如果其中执行的线程已经执行完毕,线程池中的其他等待的线程会被激活并执行。newCachedThreadPool不用指定活动线程的数量,如:ExecutorService executor = Executors.newCachedThreadPool();这个线程池不会限制执行线程的数量,如果所有的线程都是活动状态,而且又产生了新的任务,这时该线程池会创建一个新的线程来执行该任务。而newFixedThreadPool当活动线程的数量达到创建时指定的数量限制时,则必须要其中一个线程中止,才会产生新的线程来执行等待的任务。

executor.execute();这句话用来执行任务。用线程池的话,最后必须要执行shutdown()方法。因为执行该方法会停止接收新的任务,这样当所有的线程都结束后,程序就会自动退出,如果不执行该方法,则程序会一直等待接收新的任务,而不会退出程序。而判断线程池里的线程是否都结束了,可以用while(!executor.isTerminated())来判断,注意,一定要是while循环。