• 八股文第十一天


    日期:2022年8月4日

    核心参数(高薪常问)

    corePoolSize:核心线程池的大小 
    
    maximumPoolSize:线程池能创建线程的最大个数 
    
    keepAliveTime:空闲线程存活时间 
    
    unit:时间单位,为 keepAliveTime 指定时间单位 
    
    workQueue:阻塞队列,用于保存任务的阻塞队列 
    
    threadFactory:创建线程的工程类 handler:饱和策略(拒绝策略)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    线程池的原理(高薪常问)

    在这里插入图片描述
    线程池的工作过程如下:
    当一个任务提交至线程池之后,
    1 线程池首先判断核心线程池里的线程是否已经满了。如果不是,则创建一个新的工作线程来执行任务。否则进入 2

    2 判断工作队列是否已经满了,倘若还没有满,将线程放入工作队列。否则进入 3

    3判断线程池里的线程是否都在执行任务。如果不是,则创建一个新的工作线程来执行。 如果线程池满了,则交给饱和策略来处理任务。

    拒绝策略(了解)

    ThreadPoolExecutor.AbortPolicy(系统默认): 丢弃任务并抛出 RejectedExecutionException 异常,让你感知到任务被拒绝了,我们可以根据业务逻辑选择重试或者放弃提交等策略 
    
    ThreadPoolExecutor.DiscardPolicy:也是丢弃任务,但是不抛出异常,相对而言存在一定的风险,因为我们提交的时候根本不知道这个任务会被丢弃,可能造成数据丢失。 
    
    ThreadPoolExecutor.DiscardOldestPolicy: 丢弃队列最前面的任务,然后重新尝试执行任务(重复此过程),通常是存活时间最长的任务,它也存在一定的数据丢失风险 
    
    ThreadPoolExecutor.CallerRunsPolicy:既不抛弃任务也不抛出异常,而是将某些任务回退到调用者,让调用者去执行它
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    线程池的关闭(了解)

    关闭线程池,可以通过 shutdown 和 shutdownNow 两个方法

    原理:遍历线程池中的所有线程,然后依次中断

    1、shutdownNow 首先将线程池的状态设置为 STOP,然后尝试停止所有的正在执行和未执行任务的线程,并返回等待执行任务的列表。

    2、shutdown 只是将线程池的状态设置为 SHUTDOWN 状态,然后中断所有没有正在执行任务的线程 。

  • 相关阅读:
    内衣洗衣机什么牌子好又便宜?实力非凡机型深度测评
    济南某类国企单位面试复盘
    自顶向下Redis分布式锁-前篇
    TextView下划线另一种方案
    出海 SaaS 企业增长修炼手册2:Kyligence 落地 PLG 是如何避坑的?
    Linux学习 - vi/vim编辑器
    【Java】多态中调用成员的特点
    ​Unity Vuforia 新手(图片识别)教程,后续整理 实体识别 详细流程
    归并排序--排序算法
    app发布前要做的几件事
  • 原文地址:https://blog.csdn.net/weixin_44233087/article/details/126159288