4 回答
TA贡献2036条经验 获得超8个赞
以下仅为个人做法,仅供参考。
Controller
层:
在没有AOP
或Filter
介入的情况下,个人认为这里的所有方法内产生的异常都要处理;
DAO
层:
这一层的异常多为SQL异常,一般抛给Service
层处理;
Service
层:
如果认为该异常无需调用者介入处理,则在Service内部处理,反之则抛给调用者处理(其实就是甩锅……);
只有一种情况下,我才会catch之后再throw一个Exception
,就是catch了A异常,然后抛出了B异常,这通常跟使用AOP
统一处理异常搭配,例如:catch了A,B,C异常,统一交给AOP
的D异常处理器处理。
TA贡献1811条经验 获得超5个赞
TA贡献1862条经验 获得超7个赞
几个个人建议:
(1)检查型异常转为RuntimeException
,抛这个一般认为是bug
(2)自定义异常(业务异常)继承自RuntimeException
,设计自定义异常的时候要考虑异常抛出的时候能够通过日志信息快速重现发生异常的场景。
(3)关于是否抛出异常,一般来说如果需要调用方知晓可能会发生业务异常,并能处理的,就抛。如果调用方无法处理的异常,就catch掉。简而言之就是不要“甩锅”。
(4)强烈不建议catch Exception
,这种代码在发生异常的时候很难快速定位问题。
TA贡献1880条经验 获得超4个赞
建议Dao
层,直接往上抛异常(一般都是数据库的运行时异常),Service
层因为是暴露给其它应用的,并且会有很多业务信息需要传递给上层的调用者,所以这里有两种方式
通过抛出业务异常来,告知调用方具体的业务异常信息/系统异常信息(系统异常,上层可能不会关注)
Service
中保证不会出现异常,并且返回一个Result
给上层,Result
里面包括的信息有:这次调用是否成功,如果失败会有一些业务信息
所以不用层层都去抓异常,如果要处理就在Service
中处理(不管是单应用还是以后的服务化),具体在service中是以上述的哪种方式,具体看团队的选择了
大体的业务流程我们是用try{}catch{}来控制,还是用if()来控制
添加回答
举报