线程池的使用

为什么要使用线程池?

答:因为对于并发度很高的应用程序来说,频繁的创建线程将会浪费时间,降低应用程序的效率,所以创建一个线程池,可以实现线程的复用,提高并发任务的处理速度与效率

线程池的一些基本概念

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);


参考博客:线程池的使用 线程池的四种创建方式

你可能感兴趣的:(java)