我的天!e.printStackTrace() 导致内存锁死,你敢信?

点击蓝色“小哈学Java”关注我哟

加个“星标”,第一时间获取小哈推送的文章哦!


我的天!e.printStackTrace() 导致内存锁死,你敢信?_第1张图片

来源:http://dwz.cn/tQe4fLeD



e
.printStackTrace()
会导致锁死?这仅仅是打印啊,怎么可能?!

先别惊呼不可能,且听我细细道来。

先看截图1:

我的天!e.printStackTrace() 导致内存锁死,你敢信?_第2张图片

注意右下角区域,红框部分。这块内存是什么呢?非堆!那么,左边是代码缓存区内存,右边红框就是字符串池,常量,基本类型数据的内存区。然后呢?已经满了。什么原因呢?e.printStackTrace()

满了的后果呢?整个web服务,访问之后,没响应了,就当是卡死掉了。

再来看截图2:

我的天!e.printStackTrace() 导致内存锁死,你敢信?_第3张图片

看看有多少web的请求线程,被卡住在打印这一步!原因呢?要打印字符串输出到控制台上,那你字符串常量池所在的内存块要有空间啊。然而,因为 e.printStackTrace()语句要产生的字符串记录的是堆栈信息,太长太多,内存被填满了!注意 上面代码语句:4208行!

来看图3:

我的天!e.printStackTrace() 导致内存锁死,你敢信?_第4张图片

没毛病,没没事儿找事儿冤枉谁。就是这句代码惹的祸!当然,我承认,被 try 住的代码本身就有问题,导致很多调用都会抛异常。

那么,让我们再来理理整个事件产生的经过:

短时间内大量请求访问此接口 -> 代码本身有问题,很多情况下抛异常 -> e.printStackTrace() 来打印异常到控制台 -> 产生错误堆栈字符串到字符串池内存空间 -> 此内存空间一下子被占满了 -> 开始在此内存空间产出字符串的线程还没完全生产完整,就没空间了 -> 大量线程产出字符串产出到一半,等在这儿(等有内存了继续搞啊)-> 相互等待,等内存,锁死了,整个应用挂掉了。

综上,这就是 e.printStackTrace() 引发的血案。

总结当然重要,有3点:

1,代码质量啊亲,代码不抛异常咱不就能愉快的继续浪么?

2,不要使用 e.printStackTrace() 啊,这玩意儿,在项目发布后,除过不断的刷控制台,并没用什么卵用啊,您到是用 log 对象输出到日志文件里面啊。

3,推及开来,在java中,会产生大量字符串的方法,使用时,一定得悠着点,别一不小心撑到肚子(字符串池所属的那么点非堆内存空间),撑到肚子了,会死的啊 。

免费无套路分享 | 面试&学习福利资源

最近在网上发现一个不错的 PDF 资源《Java 核心知识&面试.pdf》,内容覆盖很广,Java 核心基础、Java 多线程、高并发、Spring、微服务、Netty 与 RPC、Zookeeper、Kafka、RabbitMQ、Habase、设计模式、负载均衡、分布式缓存、Hadoop、Spark、Storm、云计算等

获取方式: 关注本公众号: 小哈学Java, 后台回复资源,既可免费无套路获取资源链接

640?

更多推荐内容

↓↓↓

面试题:说说看,Nginx 都能做些什么?

面试题:说说看,你是如何对SQL进行性能优化的?

一文教您如何通过 Docker 搭建 Ngnix,反向代理,并配置 Https 证书

面试官:大数据量sql分页查询很慢,有哪些优化方案?

面试题:谈谈 Redis 热点 Key 如何发现,解决方案有哪些

面试官:说说看,线上发生Mysql死锁,你的排查思路?

如何优雅地生成那些花里胡哨的复杂样式 Excel 文件?

为什么阿里巴巴代码规约要求避免使用 Apache BeanUtils 进行属性复制

如果你喜欢本文

请长按二维码,关注小哈学Java

640?wx_fmt=jpeg

转发朋友圈,是对我最大的支持哟

如果你喜欢这篇文章,在看,转发吧。

相信明天更加美好 (*^__^*) 

你可能感兴趣的:(我的天!e.printStackTrace() 导致内存锁死,你敢信?)