java自定义异常打印内容详解
本文实例为大家分享了java自定义异常打印内容的具体代码,供大家参考,具体内容如下
背景:在开发中,我们可能会使用到自定义异常,但是,这个自定义异常在打印日志时,往往打印的内容比较多。
1.自定义异常打印内容
可以看到,虽然我们使用的是自定义异常,但是当抛出时,还是会打印出堆栈的全部信息。
2.查看源码
通过查看源码,我们可以得知,当抛出异常时,程序会调用此异常的fillInStackTrace方法,但是,大部分异常都没有对该方法做处理。基本是调用super的方法。
可以看到,此方法的父类实现,是在Throwable类中。而且此方法加了synchronized锁,查看堆栈的信息。那么必然会影响性能。
底层实现是native,调用C语言的方法。
3.解决方法
①.编写自定义异常
//此处为lombok注解 @Getter @AllArgsConstructor publicenumExceptionEnum{ AUTH(1,"认证异常") ; privateIntegercode; privateStringmsg; } publicclassAppExceptionextendsRuntimeException{ publicAppException(ExceptionEnumexceptionEnum){ super(exceptionEnum.getMsg()); } //关键 @Override publicThrowablefillInStackTrace(){ returnthis; } publicstaticvoidmain(String[]args){ thrownewAppException(ExceptionEnum.AUTH); } }
②.重写fillInStackTrace方法
重写该方法后,会只打印第一条信息,这样不仅可以节省日志空间,方便查看,更可以提高部分性能。
@Override publicThrowablefillInStackTrace(){ returnthis; }
③.打印内容
可以看到,打印内容明显变少
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。