线程池

作者: 多关心老人 | 来源:发表于2019-02-28 23:26 被阅读0次

1、线程执行的任务发生异常,默认线程是把堆栈信息抛到控制台。
2、如果线程设置了UncaughtExceptionHandler,那么这个UncaughtExceptionHandler就会被执行,这个handler只适用于这个线程没有自己处理异常及其他处理异常的Handler。
3、线程抛出异常,这个线程就死了。
4、线程池submit()任务,如果任务抛出异常,这个线程会把异常吃了,并把异常信息赋值给FutureTask的outcome,代码FutureTask:

public void run() {
       if (state != NEW ||
           !UNSAFE.compareAndSwapObject(this, runnerOffset,
                                        null, Thread.currentThread()))
           return;
       try {
           Callable<V> c = callable;
           if (c != null && state == NEW) {
               V result;
               boolean ran;
               try {
                   result = c.call();
                   ran = true;
               } catch (Throwable ex) {
                   result = null;
                   ran = false;
                   setException(ex);
               }
               if (ran)
                   set(result);
           }
       } finally {
           // runner must be non-null until state is settled to
           // prevent concurrent calls to run()
           runner = null;
           // state must be re-read after nulling runner to prevent
           // leaked interrupts
           int s = state;
           if (s >= INTERRUPTING)
               handlePossibleCancellationInterrupt(s);
       }
   }

如果Future不调用get()的话,那么这个异常就永久消失了。
如果调用get()的话,任务中抛出的异常会被封装成ExecutionException(your throwable)返回给你。
5、execute() 会抛异常,要么直接抛到system.err, 要么被你的uncaughtExceptionHandler捕获
6、submit() 永远不会抛异常,除了future.get()。

  • 线程池是如何保持core size数目的线程不死?
    如果不允许core线程死亡,通过queue.wait()来保存线程阻塞。
    7、不要调用Executors工具类来生成线程池,因为用的是无界队列,会OOM
    8、coreSize, maxSize和blockingQueue在提交任务时:如果池中线程数小于coreSize,会自动创建新线程执行;池中线程数大于coreSize且小于maxSize,进入队列;队列满了,会创建新线程;池中线程数大于maxSize,走拒绝策略。AbortPolicy:抛异常,DiscardPolicy:不干任何事;DiscardOldestPolicy:抛弃最老的一个任务,新任务进队列;CallerRunPolicy:调用者执行,最常用。
    9、防止线程池被强制关闭,一般kill -15 PID,jvm需要注册shutdownHook,调用线程池的shutdown,可以设置awaitTime内关闭。

相关文章

  • java线程池

    线程VS线程池 普通线程使用 创建线程池 执行任务 执行完毕,释放线程对象 线程池 创建线程池 拿线程池线程去执行...

  • java----线程池

    什么是线程池 为什么要使用线程池 线程池的处理逻辑 如何使用线程池 如何合理配置线程池的大小 结语 什么是线程池 ...

  • Java线程池的使用

    线程类型: 固定线程 cached线程 定时线程 固定线程池使用 cache线程池使用 定时调度线程池使用

  • Spring Boot之ThreadPoolTaskExecut

    初始化线程池 corePoolSize 线程池维护线程的最少数量keepAliveSeconds 线程池维护线程...

  • 线程池

    1.线程池简介 1.1 线程池的概念 线程池就是首先创建一些线程,它们的集合称为线程池。使用线程池可以很好地提高性...

  • 多线程juc线程池

    java_basic juc线程池 创建线程池 handler是线程池拒绝策略 排队策略 线程池状态 RUNNIN...

  • ThreadPoolExecutor线程池原理以及源码分析

    线程池流程: 线程池核心类:ThreadPoolExecutor:普通的线程池ScheduledThreadPoo...

  • 线程池

    线程池 [TOC] 线程池概述 什么是线程池 为什么使用线程池 线程池的优势第一:降低资源消耗。通过重复利用已创建...

  • java 线程池使用和详解

    线程池的使用 构造方法 corePoolSize:线程池维护线程的最少数量 maximumPoolSize:线程池...

  • 线程池

    JDK线程池 为什么要用线程池 线程池为什么这么设计 线程池原理 核心线程是否能被回收 如何回收空闲线程 Tomc...

网友评论

      本文标题:线程池

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