自定义异常的性能问题:避免打印繁重的“栈”信息

Java中频繁实例化带栈信息的自定义异常会导致内存开销增大。通过避免调用`fillInStackTrace()`方法,可以优化性能。自定义异常如`ParamException`可继承`RuntimeException`并设置`writableStackTrace`为`false`,从而避免打印栈信息。然而,在分布式系统中,这可能增加诊断复杂性。
摘要由CSDN通过智能技术生成

Java每实例化一个Exception,就会对当时的栈进行快照,如果该动作发生的比较频繁,对内存的开销也就不可忽略了!

常见的自定义异常格式:

public class ParamException extends RuntimeException{

    public ParamException() {
        super();
    }
    public ParamException(String message) {
        super(message);
    }
}

抛出业务异常段代码:

    @GetMapping("/valid")
    public Object test(String param){
       if (param == null){
           throw new ParamException("参数为空");
       }
       return Res.success();
    }

打印出来的业务异常信息:

2020-12-21 14:54:38.328 ERROR com.hrbank.aspect.ExceptionAdvice >> system.exception.occur
com.hrbank.exception.ParamException: 参数为空
	at com.hrbank.controller.ManageAdvertiseController.test(ManageAdvertiseController.java:63)
	at com.hrbank.controller.ManageAdvertiseController$$FastClassBySpringCGLIB$$6b367347.invoke(<generated>)
	at org.springframework.cglib.proxy.MethodProxy.invoke(MethodProxy.java:218)
	at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.invokeJoinpoint(CglibAopProxy.java:769)
	at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163)
	at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:747)
	at org.springframework.validation.beanvalidation.MethodValidationInterceptor.invoke(MethodValidationInterceptor.java:120)
	at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
	at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.proceed(CglibAopProxy.java:747)
	at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:93)
	at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186)
	at org.springframework.aop.framework.CglibAopProxy$CglibMethodInvocation.p
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值