Java基础系列:JDK8堆栈e.printStackTrace追踪

1 e.printStackTrace()信息去哪里了

JDK8中,元空间替换方法区,并将方法区中的常量池移到堆中,而e.printStackTrace()将字符串常量,输出到堆中。

  • 正常接口调用

在这里插入图片描述

图1 正常程序
  • 异常接口调用
    抛出异常,并打印堆栈信息e.printStackTrace()

在这里插入图片描述

图2 异常程序打印堆栈信息

对比正常程序和异常程序的Eden内存区状态,正常程序的堆增长正常,而异常程序持续抛出异常并且打印堆栈追踪信息,异常信息会进入堆中(Eden内存),可知JDK8中,方法区的字符串常量池移至堆中,并且,Eden区中存储运行中生成的对象,由此可知,每次异常都会生成一个Exception对象,该对象的方法printStackTrace()获取异常信息。

2 小结

  • catch住的异常,应当输出到日志系统中,而不是直接打印到堆中
  • JDK8方法区中的常量池移至堆中
  • 抛出异常即新建一个Exception对象,调用printStackTrace()方法获取异常信息,异常信息进入堆
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天然玩家

坚持才能做到极致

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值