这个话题不大,但是很能体现出程序员的内功~各种框架工具那都是招式兵刃,我们一定不能把内功的修炼给忽视了,否则绝难打通任督二脉~嘎嘎~扯远了~

 

异常分为两类:checked & unchecked exception

 

先看一下几个常见的java中的unchecked excetion(RuntimeException)

ArithmeticException

ClassCastException

IndexOutOfBoundsException

IllegalArgumentException

NullPointerException

上面的几种异常类型可以引申出RuntimeException的使用场景--

RuntimeException在正常的程序执行中是不应该出现的,无论程序的运行场景是什么样的~

 

RuntimeException可以看做是一种错误,理论上上层程序是可以检测并避免的~~如果上层程序员不负责任,那么不好意思,下层程序就用抛出RuntimeException的方式来响应你~~~

 

checked exception相比RuntimeException来说,更多的是给上层传递了一些信息,比如:

UserNotFoundException

PasswordErrorException

并且强制要求上层程序一定给出在遇到checked exception的时候的处理逻辑。就是说,我们认为在遇到checked exception的时候上层程序是走到了一个相对比较少见的情形,但是这仍然是可以接受的.可以理解为一种另类的分支语句~~~

但是如果可以使用分支语句解决的,我们还是尽量采用分支来解决而不是去使用异常,估计这一点也是C#这种语言不提供checked exception这种异常的原因之一

 

对于异常处理的额外几点:

 

1、系统边界处,如在WEB中与前端交互的Controller中,在为其他系统提供的接口处,都要注意捕获所有异常,然后把异常转换为约定格式的交互数据

 

2、返回给前端的信息与log信息不应该一样,比如我们可以写一个Controller层的AOP处理逻辑来捕获所有的异常

 

public class BaseC extends Controller {

    protected static final Log log = LogFactory.getLog(BaseC.class);

    @Catch(Throwable.class)

    public static void handleThrowable(Throwable throwable) {

        log.error(ExceptionUtils.getStackTrace(throwable));

        renderJSON(new ReturnData(false, "Unknown Error~~mail to hxabc@baidu.com,3ks!", throwable.getMessage()));

    }

}

 

 

 

 

 

3、异常链问题:

异常在上层抛出的时候的处理原则:如果当前类处理不了,那就继续往上抛,如果所有的类都处理不了,比如DBException,就直接给用户一个提示就好了,但是在这个异常链处理过程中,异常不应该丢失,记log,继续throw

 

4、类库或者模块应该定义自己的异常基类,比如jdbc那套接口,有一个公共的异常基类:SQLException,然后再根据具体的情况抛出定制化的异常,提供尽量详细的信息,比如:

SQLTimeoutException

SQLFeatureNotSupportedException

SQLInvalidAuthorizationSpecException

 

5、Thinking in java的作者说:大多数时候,异常类其实只需要一个良好定义的类名~~我们在设计异常类的命名时一定要做到准确清晰~~

 

本文首发于【