温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

java中使用e.printStackTrace()输出日志让系统崩掉怎么办

发布时间:2022-01-04 09:46:22 来源:亿速云 阅读:858 作者:小新 栏目:云计算

这篇文章主要介绍java中使用e.printStackTrace()输出日志让系统崩掉怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

聊一个你可能会经常犯的一个错误!使用 e.printStackTrace() 输出日志是怎样让系统崩掉的!

从方法 printStackTrace 自注释上来看,该方法是输出打印异常的堆栈跟踪信息的。由于,我们从学习 Hello World 的那一天开始,老师就是使用 printStackTrace 输出错误日志的,导致很多人一直错误的使用它并沿用至今!

printStackTrace 严重的来说,它可能会导致我们的系统崩溃。因为,e.printStackTrace() 在打印异常到控制台时,会将产生错误堆栈字符串存入到字符串池内存空间,如果此时的空间比较小,并且异常多,此内存空间可能一下子就被占满了,并且有些在此内存空间产出字符串的线程还没完全生产完整,就没空间了,导致大量线程产出字符串产出到一半,都等在这了,相互等待,等空闲内存,最终会抛出 OOM,导致整个应用挂掉。

在这种情况下,如果使用 java jvisualvm 来查看内存使用情况,你会发现下图中最右侧的非堆区域,也就是字符串常量池已经满了!  

java中使用e.printStackTrace()输出日志让系统崩掉怎么办

在接着查看线程信息。  

java中使用e.printStackTrace()输出日志让系统崩掉怎么办

你会发现,大量的线程被卡在了异常输出的位置。通过具体的行号信息,查看源码。  

java中使用e.printStackTrace()输出日志让系统崩掉怎么办

确实是 e.printStackTrace() 的锅。

那么该怎么解决呢?

1、提高代码质量,从源头解决。先解决为什么会抛异常。
2、增加内存,增加非堆内存,增加字符串常量池的内存。
3、禁止使用 e.printStackTrace() 输出日志。
4、提升系统的容错能力。

除此之外,e.printStackTrace() 是将日志输出到控制台,如果我想将日志输出到文件,或者第三方服务器上,它就无能为力了。而如果你的系统中大量的使用了 e.printStackTrace(),那么改动的时间和代价就太大了!

另外,也有不少人喜欢使用 System.out.println() 输出日志。我也非常不建议,去年我还写过一篇关于 System.out.println 危险性的文章。不知道大家是否还记得?  都 9102 了,你还不知道 System.out.println 的危害!

以上是“java中使用e.printStackTrace()输出日志让系统崩掉怎么办”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI