java 线程池 学习记录

线程池构造函数参数有哪些


  • 核心线程池
  • 最大线程数

  • 空闲非核心线程存活时长
  • 空闲非核心线程存活时长单位

  • 阻塞队列

  • 线程生产工厂

  • 拒绝执行处理类

execute和submit有什么区别?

  • execute会抛出异常
  • submit不会抛出异常

线程池怎么处理异常

  • 方式一:继承线程池,重写execute/submit,并使用try catch处理异常
  • 方式二:重写线程生产工厂,给每个生产的线程类设置UncaughtExceptionHandler

如果想要在执行过程中把ThreadLocal参数进行传递,该怎么操作?

  • 继承线程池类
  • 重写submit方法
    • 在submit的时候将ThreadLocal/MDC参数,提取并放到Runnable的私有属性中
    • 在Runnable中的run方法执行的时候,将私有属性中的ThreadLocal参数或者MDC参数放到当前线程的ThreadLocal或者MDC中
    • run方法执行结束后,需要把当前线程中ThreadLocal参数或者MDC参数清空

线程池的执行过程

  • 当有任务提交的时候,检查核心线程是否满了
    • 没满,启动新的线程进行执行
    • 满了,则将任务放到阻塞队列中去
  • 当阻塞队列满了,检查线程数是否已经到达最大线程数
    • 没到达最大线程数,启动新的线程处理任务
    • 满了,调用拒绝执行处理类进行处理

线程池

  • 类:ThreadPoolExecutor
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章