5. 线程池

1. 线程池是什么?

  • 在创建线程和销毁线程的时候,需要使用一定的资源开销;
  • 使用多线程的场景很多,需要频繁使用线程的时候,如果每个线程执行结束便销毁,就会不断重复创建线程->使用线程->销毁线程的操作,浪费大量的资源在创建和销毁线程的工作上;
  • 为了避免这种资源浪费,更合理的利用系统资源,那么就需要使用到池化技术了;
  • 创建一定数量的共享线程放入一个池子中,当有任务执行时便将从池子里抽取出线程使用,使用完了之后再将线程放回线程池,用于循环利用。

2. 常用的线程池有哪些?

  • 我们常见的线程池通常可以通过 Executors 得到,但是不建议直接使用 Executors 对象创建线程池;
  • 线程池的种类主要根据其核心线程数量,非核心线程数量,非核心线程的存活时间三项参数的不同来区分的;
  • 常见的线程池种类:
  1. 单线程线程池:仅有一个核心线程,没有非核心线程的线程池
  2. 固定线程线程池:固定数量的核心线程,没有非核心线程的线程池,常使用的线程池;
  3. 自动回收线程池:没有核心线程,不限数量的非核心线程,非核心线程存活一定时间。使用场景是应对任务不均匀的场景,在任务非高峰期节省线程资源,在任务高峰期的时候常见多个线程来满足任务需求,快速完成任务,并在结束任务之后销毁线程。
  4. 定时调度线程池:线程数量不限制,支持定时调度执行线程。

3. 不同线程池的使用场景是什么?

  1. 单线程线程池:主要是为了让任务按提交的顺序执行。
  2. 固定线程线程池:负载比较重,而且负载比较稳定的一个场景。
  3. 自动回收线程池:负载不稳定的场景,低峰期销毁空闲线程,回收资源,高峰期创建线程,需要多少创建多少,快速完成任务。

4. 说一下线程池配置的几个参数以及线程池启动线程的原理(说说线程池的底层原理)?

  • 线程池全部总共有个参数,具体如下:

  • 核心线程数量

  • 最大线程数量

  • 空闲线程等待时间

  • 空闲线程等待时间单位

  • 线程工厂

  • 拒绝策略

  • 线程池的原理如下:

image.png

5. 线程池被关闭的方式有哪几种?

  • 主要的关闭方式有两种shutdown/优雅关闭shutdownNow/立即关闭
  • shutdown:不允许提交新的任务,等待前面所有的任务执行完了,才会真正的关闭线程池;
  • shutdownNow:返回还没有执行的task列表,立即强制关闭线程池。

6. 线程池队列满的时候怎么处理(FixedThreadPool满了之后会怎么办)?

  • 当线程池的等待队列满了,线程数量也满了之后,再提交任务到线程池的话,将会触发线程池的拒绝策略 RejectedExecutionHandler
  • JDK默认定一个几种拒绝策略,同时也支持开发者自定义策略:
  1. AbortPolicy:在当前线程抛出拒绝接收任务的错误;
  2. CallerRunsPolicy:如果线程池没有关闭,在当前线程执行该任务;
  3. DiscardOldestPolicy:将任务等待队列顶部任务弹出抛弃,将新添加的任务添加进程等待队列;
  4. DiscardPolicy:抛弃当前任务;
  • 使用 Executors 创建的线程池默认使用 AbortPolicy 策略

你可能感兴趣的:(5. 线程池)