为什么要使用线程池?
答:因为对于并发度很高的应用程序来说,频繁的创建线程将会浪费时间,降低应用程序的效率,所以创建一个线程池,可以实现线程的复用,提高并发任务的处理速度与效率
线程池的一些基本概念
1、corePoolSize:核心池大小,即拥有的线程数量
2、maximumPoolSize:最多线程数量,即能够创建的最大数量的线程
3、keepAliveTime:没有任务时线程存在多久会销毁
3、Unit:时间单位
4、workQueue:缓存队列,缓存等待处理的线程
5、execute():提交一个线程到线程池中
6、shutdown():关闭线程池
使用线程池的几种方式?
1、可以用ThreadPoolExecutor函数直接创建,示例:
ThreadPoolExecutor executor = new ThreadPoolExecutor(5,10,200, TimeUnit.MILLISECONDS,new ArrayBlockingQueue(5));
2、使用Executors类的静态方法创建:
//创建单个线程的线程池
ExecutorService ex=Executors.newSingleThreadExecutor();
//创建固定数量的线程池
ExecutorService ex=Executors.newFixedThreadPool(num);
//创建具有缓存功能的线程池
ExecutorService ex=Executors.newCachedThreadPool();
//创建定时以及周期性的执行任务定时任务的线程池
ScheduledExecutorService ex=Executors.newScheduledThreadPool(num);
…
//参数1:目标对象 参数2:隔多长时间开始执行线程, 参数3:执行周期 参数4:时间单位
ex.scheduleAtFixedRate(rn, 3, 1, TimeUnit.MILLISECONDS);
参考博客:线程池的使用 线程池的四种创建方式