查看原文
其他

Java异常排行榜:哪个异常最常见?

忆蓉之心 Java面试那些事儿 2019-12-19

前段时间写了一篇关于异常的文章《谈谈异常》,感觉不少同学比较感兴趣,最近,发现国外有一个网站专门搜集 Java 异常。

在该网站上,搜集了大量 Java 程序崩溃时的堆栈跟踪信息。我们几乎能在这里找到经常遇到的 Java 异常信息。该网站根据不同的标准对崩溃信息进行了分类处理,如异常类型,组件抛出的异常,以及这些异常的主要来源。

一般来说,你在该网站上查到的异常类型会按照不同堆栈信息及来源进行整理并返回结果,如下图所示:

最近,该网站对所有的异常数据进行了数据分析,分别按照如下三种不同的维度进行分析。

1、搜集到的崩溃次数

上图为崩溃的次数的分析结果,我们可以发现,NullPointerException 毫无悬念是迄今为止最常见的异常。

2、出现与异常堆栈信息相关的网页数

同样,NullPointerException 也是出现次数最多的异常。与之前的区别在于一个网页可能会包含多个不同的堆栈跟踪「例如,将多个堆栈跟踪粘贴到单个 GitHub 问题中」。我们可以看到,异常类型的顺序存在一些差异:例如,IllegalArgumentException 和 IllegalStateException 在网页中出现的次数比它们在搜集到的崩溃次数排名更靠前。

3、异常的报错模式数

我们可以看出,一些异常类型的排名低于第一个图表;这意味着更少的报错模式连接到它们,但这些报错模式平均有更多的崩溃;比如 ClassNotFoundException、NullPointerException,它虽被许多开发人员共享,但收集的平均崩溃次数要少得多,通过下图更能说明这一点。

我们可以看出,在 NullPointerException 的情况下,有超过30,000个模式,每个模式连接崩溃少于10次,65个模式100-999次崩溃。在 ClassNotFoundException 的情况下,只有10000个模式的相关崩溃少于10个,但与 NullPointerExceptions 相比,有更多的模式和超过100次的崩溃。甚至有1000多个连接崩溃的模式,一个模式有超过10000个连接崩溃。

这个结果确实让人很惊讶,引起这一现象的原因:调用导致 NullPointerException 引发崩溃的代码是相当分散的,因为它们来自许多不同的库,并且在出错时立即生效,而 ClassNotFoundException 由 JVM 的标准机制生成,因此会导致许多堆栈信息具有相同的错误模式。

有人可能会认为,NullPointerException 和 ClassNotFoundException 都是如此基本的异常,以至于每个开发人员都知道如何轻松解决它们,但它们在论坛上频繁出现的情况与此假设相矛盾,因为关于如何处理它们的方案会有所不同。在 NullPointerException 的情况下,很难写出一些通用的解决方案,因为每个库中的问题都不相同。在ClassNotFoundException 的情况下,很多开发人员都会遇到一些常见的报错模式;当然,针对您使用的不同环境或框架有特定的解决方案,但提供的一般解决方案仍然有意义。

通过异常报错模式数得出的结论是:即使有更多的 NullPointerException 异常,ClassNotFoundException 应该更靠前。

通过上面的图表分析结果,相信你也遇到了上面出现的这些常见异常,无论该平台按照那种方式进行分析,作为开发的我们,没必要在意异常排名结果,只需关注常见的异常,并理解产生这些异常的原因!!!

Java面试那些事儿长按关注,分享最有趣的Java知识点。

推荐阅读:

谈谈异常

基于Nginx+lua的蓝绿发布系统

    您可能也对以下帖子感兴趣

    文章有问题?点此查看未经处理的缓存