为了账号安全,请及时绑定邮箱和手机立即绑定

Java错误代码及异常处理

Java错误代码及异常处理

慕森卡 2019-03-21 19:15:32
现在有个项目,遇到错误代码和异常处理方面的问题,请教各位高手。背景:项目对外提供服务,这些服务是对很多外部系统提供服务的封装,每个外部系统有自己的错误代码,没有统一的规范。有些外部系统自己规范都不统一,有的时候返回错误代码,有的时候返回错误信息,有的时候错误代码和错误信息在一起。目前可选的解决方案:一、直接使用外系统错误代码方法:直接使用外系统错误代码问题:混乱,错误代码可能重复,排除该方法二、使用统一的错误代码方法:对外部系统的错误代码重新编排,按照模块进行分类,没有错误代码的错误当做未知错误。问题:需要维护一个错误代码列表及映射关系,对于外部系统错误不规范的情况,需要有专门的代码进行处理三、使用异常,统一当做checked exception处理方法:继承Exception问题:不符合异常处理最佳实践,有些应该是RuntimeException的也被强制要求捕获了四、使用异常,根据外系统错误类型区分是checked exception还是unchecked exception方法:根据外部系统类型,区分哪些是程序逻辑问题(继承RuntimeException),哪些是系统问题(继承Exception),映射成不同的异常类型问题:外系统错误说明可能有误,导致映射到异常时类型不准确针对这种情况,各位觉得应该使用哪种方式处理比较好,另外,对于异常的类层次结构实践经验不多,只是简单看过Spring的异常类设计,有哪些好的书或资料可以学习一下。
查看完整描述

3 回答

?
饮歌长啸

TA贡献1951条经验 获得超3个赞

1、如果你这个系统是新系统/或者以后会有更多的子系统依赖 建议还是规范起来 
1.1、如果对外提供的是jar包直接抛异常 没关系
1.2、如果走如http/webservice 提供一个异常到错误码的映射(比如直接写到异常里) 这个是标准的 以后的标准
1.3、对于遗留系统 提供一个转换处理器(如spring对jdbc、hibernate等的都转换为DataAccessException)
如果外部系统能改造的话 建议沟通下一起改造下 否则就要他们提供当前系统的错误码 然后联调(可能存在bug 很正常的 所以要全面测试)

1.4、考虑下spring的NestedException 嵌套异常 来存储原始异常
1.5、如果可以放弃checkedException 如web系统都会有一个异常解析器 出错了 会交给他 所以unchecked即可

查看完整回答
反对 回复 2019-04-28
?
小唯快跑啊

TA贡献1863条经验 获得超2个赞

“简单是最好”,我推荐第二种。

  1. 自定义异常,继承自RuntimeException。

  2. 映射不一定需要。我觉得外系统id + 错误代码(没有时自己定制)足以简单区分异常。

【1】里面可能需要定义两个,业务异常和系统异常。但无论哪种都是RuntimeException。
(是否runtime这个有争论,我个人推荐全部runtime,无须强制捕捉。)

总之,

  • 继承层数少些

  • 结构简单些。

  • 无须强制 <- 个人意见

最后,统一处理所有异常的地方可能需要映射,不同异常对应不同处理方式。
如果没有这种需求,也无须搞映射。能区分即可。

“如无必要,勿增实体”——奥卡姆剃刀定律


查看完整回答
反对 回复 2019-04-28
  • 3 回答
  • 0 关注
  • 1560 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信