一、为什么要有异常机制?
1、在传统语言C语言中,当你操作资源时,一般是通过函数返回值code来判断是否执行成功(一般是失败返回小于零的整数)。
2、脚本语言,比如Python、PHP等,由于没有返回类型的限制,一般是return false on failed。当然,这些脚本语言也有异常机制。
3、多返回值语言(Golang),一般是通过返回多个值(可能包含error对象),然后通过error值来判断操作是否成功。
二、总结
从上面几个例子可以看出,①返回错误码②返回false等,这些错误信息不够清晰,很多时候也避免不了层层嵌套判断的漩涡中。③的方式还不错,不过每次都得check error。
作为一门静态语言,java是单返回值、返回类型确定的,当出现异常不能返回指定的类型时(当然,你可以返回null或empty object,但一般不推荐返回null),这个时候异常机制便能很好地解决这个问题。函数调用者只需关心调用这个函数会返回什么,异常需不需要这层处理还是继续往上抛,可以大大减轻调用者的负担(如果不需要这层处理,我只需关心api会返回什么,按照自己的逻辑往下写,并不需要check error,资源释放推荐使用try-with-resource)
但是如果是unchecked exception,则必须在doc注明函数会抛什么异常,以便调用者使用,这一点不管是java、python还是php。
当函数无法完成其宣称的任务的时候抛出异常!