运行的线程忽然没了,但是没有任何异常日志打印.Throwable和Exception的区别需要了解一下

Posted 请叫我大师兄_

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了运行的线程忽然没了,但是没有任何异常日志打印.Throwable和Exception的区别需要了解一下相关的知识,希望对你有一定的参考价值。

问题是这样的,弄了个类,实现runnable接口,然后,就刷刷刷的初始化了n个线程,然后通过ThreadPoolExecutor提交到线程池中运行,期望是这个run一直不停的执行,起初一切都很正常。然后就遇到了问题。分两个阶段。

第一个阶段:初级阶段。

线程的run方法在执行的,因为种种原因,出现了异常,然后,这个线程就直接GG了,导致当初提交的n个线程中出现异常的就没了,导致了问题,虽然出问题了,但是,起码还能在日志中看到错误信息,有迹可循,慢慢的排查问题,完善代码,尽量降低他异常的概率,接近于零吧。

总结的应对之法:把run里面的代码,都给他用try给包起来,catch Exception,在catch里面打印错误日志,这样,即使某次发生了异常,一般情况下异常都是出乎意料的那种,这样日志里面就能记录出错信息,也只是当次的run执行失败,也许下次处理其他数据的时候,还能正确执行呢,可以保证即使在出错的情况下,线程依然在,还是可以正常的运行,起码能在日志中看到错误信息。

第二个阶段:

虽然已经对run方法的代码,进行了全方位的try catch,catch的时候,为了百分百的catch住,使用的是catch (Exception e) ,自认为出问题的时候,必须且肯定的会在catch里面看到错误日志信息的。然而,并不是。还真就会出现catch不到的情况。导致,提交到线程池的线程,就这么没了,没留下丁点儿证据,排查问题的时候,无迹可寻。为啥呢?

原因:

究其原因,就是对Exception不了解,是真不了解,就没当回事儿。还有catch不到的异常吗?哎,还真就有。看图。

 看到,Exception只是一个派生类,我代码里面catch的都是Exception的派生类,那么出问题的时候,出的问题,不是Exception,那不就铁定catch不到了吗?那提交的线程,可不就悄咪咪的没了吗。

Throwable中包括Exception(异常)和Error(错误)。Exception专指程序本身可以处理的异常,一般性的异常。而Throwable用来定义所有可以作为异常被抛出来的类。Error(错误)是程序无法处理的错误,表示运行应用程序中较严重问题。大多数错误与代码编写者执行的操作无关,而表示代码运行时 JVM(Java 虚拟机)出现的问题。Exception(异常)是程序本身可以处理的异常。Error是一种严重的问题,应用程序不应该捕捉它。 Exception一般可能是程序和业务上的错误,是可以恢复的。

所以:

对线程中的run方法除了全方位的使用try包围之外,catch的时候,也需要专业的把(Exception e)给换成(Throwable t),这样,就能看到平常看不见的错误日志了。线程的不正常消失,就必须得留下点什么,才能走。

以上是关于运行的线程忽然没了,但是没有任何异常日志打印.Throwable和Exception的区别需要了解一下的主要内容,如果未能解决你的问题,请参考以下文章

运行的线程忽然没了,但是没有任何异常日志打印.Throwable和Exception的区别需要了解一下

异常解决——SpringBoot项目启动卡住,无任何异常信息

线程池中execute和submit的区别

log4j并发打印日志导致线程Block问题排查记录

打印异常信息到日志

tomcat假死控制台不打印任何信息也不记录日志也无法访问