使用异常处理业务逻辑的效率问题

审计日志功能要把记录值记录数据库,并根据model对象字段上Colum注解的name属性记录字段的注释。代码中在获取这个name注释时候,直接获取注解并获取name属性,当字段没注解就会有指针异常,在catch异常后,就认为没有设置注释,就设置为空。在印象中这样把异常当作业务逻辑处理的效率很低,百度也是有说明这点,然后就进行试验。
俩个方法:接收字符串,如果为空返回0,不为空返回字符串长度,
一个用异常处理:

try{
return s.length();
}catch(Exception){
return 0
}

一个不用异常

if(s==null){
return 0;
}else{
return s.length
}

测试结果

执行次数用异常不用异常
一千万次2745868
一百万次286653
十万次29363
一万次3081
一千次160

可以看出用异常的执行效率随着次数指数级增长,不用异常的效率比用异常效率快多了,所以在义务逻辑处理是尽量不要用异常。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值