Java的异常/错误机制
Javar 异常主要有两种类型:受检异常和非受检异常。
异常到底如何用?为了什么目的去用?
受检异常一般用在API层,要求客户端必须考虑在进行语句调用时必须考虑异常情况,如果出现异常了客户端程序需要依据自身的场景处理异常(记录、向上层抛出、跳转到其它处理策略)。
更细致的考虑是记录异常的策略?向上层抛出异常的策略?跳转其它分支的策略?
记录异常的策略?
- 记录异常的目的就是快速定位问题。
- 不需要重复的记录。
- 在最初产生异常的地方记录。
- 需要统一风格,考虑建设日志处理系统。
抛出异常的策略?
异常是有层级结构的,一味简单的抛出异常是没有任何意义的,关键的地方就是
- 整个处理流程是怎么个样子?
- 整个调用流程是怎么个情况?
在整个流程的某个环节会产生什么样的异常是可以被预先约定的。
比如,
- 在UI呈现层出现的异常和用户关系密切,异常信息通常不会是堆栈输出的方式。
- 在业务逻辑层出现的异常与业务和开发人员关系密切,此外这一层间接影响到UI层的异常处理,通常这一层级的异常信息是带有业务级、技术级混合的异常信息,这一层级的异常信息包含着业务标记信息和部分堆栈信息。
- 底层技术支撑这一层主要和提供的API的调用者关系密切,这一层的异常信息以堆栈信息为主。
这是可以约定的!
我们定义一套规则约束这种分层结构的软件项目,在UI层、逻辑层、技术支撑层分别定义属于每层的异常处理类(类的粒度可以自由掌握但一定要有规则),涉及到层与层之间异常数据的过滤和传递,利用继承与多态我们完全可以平滑的完成类的转换,因为我们需要的是异常信息的交换而不需要在意到底是哪个类,类的作用只是限于代码结构级别的约束而已。