美文网首页
5. 线程池

5. 线程池

作者: zekers | 来源:发表于2020-12-03 10:17 被阅读0次

    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. 线程池

          本文链接:https://www.haomeiwen.com/subject/otruwktx.html