e.printStackTrace( )是打印异常栈信息
throw new RuntimeException(e)是把异常包在一个运行时异常中抛出。
e.printStackTrace();在实际开发时意义不大,因为部署以后不会有人看控制台,这句很多情况下会被记录日志的代码代替。
throw new RuntimeException就是要把异常继续抛出,要么由上层方法解决,要么会终止程序运行,比如这里,如果初始化都无法正确完成,再继续运行下去也没有必要了。
至于说多打印一句话,还是因为在工具环境下,你比较关注控制台,实际部署环境,没人看控制台信息,都会去看日志中记录的异常信息。
我们常看见这种写法
try{
....
}catch(Exception e){e.printStackTrace( );throw new RuntimeException(e);}这是处理没法进一步处理的异常的一般做法。try块中出现了一个异常,它被catch住了,我们首先要在标准输出上打印出异常但是如果没有throw这句,这个错误就静悄悄地被catch块吃掉了,程序会继续运行。可这个时候很可能你的程序的状态已经不对了,继续下去也没有什么意义,所以应该继续抛出这个异常。你当然可以写throw e;但是这个e是一般的异常,如果这样抛出的话,你得在这个函数头上用throws来声明,比如:public void abc() throws Exception然后调用这个函数的函数也还得这么干,所以一般的处理是把e包装成运行时异常:
new RuntimeException(e),这样就不需要在函数头声明了。但这只是一般的处理方法,在实际程序中不可不顾实际情况和需求生搬硬套。
/**
* @throws Exception
* 声明抛出异常的方法method:如下:可知此method方法存在2处异常。
* 1.一处是方法的算术异常。(n = n/m;)
* 2.一处是调用会抛出异常的方法,来抛出一个异常。(throw new Exception("m不能为9");)
* *如下:我们捕获了throw new Exception("m不能为9");并做了异常处理。
* 则main方法中的try-catch会忽略已经处理过的异常,而去捕获没有经过异常处理的异常。(如:n=n/m算术异常)
* *覆盖性:
* 如果,方法体中存在'throw new Exception();'语句或者catch中存在'throw e;'语句。
* 则方法method抛出的异常即是此条语句异常,而不会抛出方法中的算术异常。
* 因此,如果,要使用'throw new Exception();'或'throw e;'语句,可先在方法体中进行捕获异常并处理。
*/
public int method() throws Exception{
int n = 100;
int m = 10;
while(m>-1){
m--;
n = n/m;//***抛出一个分母为0的算术异常
try {
if(m==9){
throw new Exception("m不能为9");//***抛出一个新的Exception异常'实例'.
}
} catch (Exception e) {
// TODO: handle exception
System.out.println("我们将对抛出异常的“语句”:throw new Exception('m不能为9')作出处理。");
e.printStackTrace();
//throw e;或者throw new Exception();//***抛出异常e实例或新的Exception实例
}
}
return n;
}
}
/**
* 总结:
* 1.throws是方法抛出异常。如: public int method() throws Exception{//code.....}
* a.如果,方法体中有异常并使用try-catch捕获异常并处理,则方法不会抛出异常。
* b.如果,方法体中有异常(如:算术异常)且没有捕获并处理;则此方法抛出的是方法体中的异常。
* c.如果,方法体中使用‘throw new Exception();’语句抛出一个新的Exception实例;则即是方法体多出一个这样的异常,
* 方法抛出的是此语句异常。
* d.如果,方法体中对异常进行了捕获却没有处理,且在catch中使用'throw e;'语句抛出异常,则即是方法抛出的是try中的异常。
*
* 2.throw是语句抛出异常。
* //***抛出异常e实例或新的Exception实例
* a.catch中的throw e;
* b.方法体中的throw new Exception();
*
* 总之,两者的作用就是简单的抛出异常。
*/