首页 > 编程语言 > 详细

讲一讲java异常时怎么回事

时间:2017-02-22 19:45:17      阅读:183      评论:0      收藏:0      [点我收藏+]

1.异常,说白了。两种,一种就是就是不能让代码通过编译的异常。另一种就是程序运行期间出现的异常。
异常就是错误,只要出现异常,程序就不会向下运行了。就不会执行后面的代码了。
这时候就可以通过显示statcktrace堆栈信息的瞬间信息,知道错误发生在什么地方,及报的什么错。
所以我们要在代码捕获异常的地方catch地方,用log打印记录下来stacktrace信息。

2.为什么对异常要进行try catch捕获?
try catch捕获异常的目的是,当异常发生时,能够继续向下执行我们的程序(即使是runtime异常),而不是程序挂掉(不捕获异常时,就会立即挂掉程序)。
将异常进行捕获的目的是,使程序不挂掉。可以向下执行。
在捕获的地方catch分句处,打印出try代码块出错的堆栈信息,然后程序代码继续向下执行。

try {
int i = 1 / 0;
} catch (Exception e) {
System.out.println("异常发生了,,不知道还能向下运行否。。。。");
e.printStackTrace();
}

logger.info("execute finished");
System.out.println("啦啦啦啦 ");
输出结果:
异常发生了,,不知道还能向下运行否。。。。
java.lang.ArithmeticException: / by zero
at APPMain.main(APPMain.java:111)
execute finished
啦啦啦

总结:所以程序继续向下运行了,这样就能达到,异常的产生并不会使程序挂掉。而使程序能继续执行。

3.输出那些异常具体信息,是通过e.printStackTrace();这个方法的,如果去掉这个方法,就不会再控制台中显示java.lang.ArithmeticException: / by zero
at APPMain.main(APPMain.java:111)这种错误提示了。
1)异常捕获的catch代码块中,直接调用e.printStackTrace(),会在控制台直接打印出来异常的信息。
2)若产生异常时,不进行e.printStackTrace(),而是在日志输出时打印e.printStackTrace()。就会将java.lang.ArithmeticException: / by zero
at APPMain.main(APPMain.java:111)这种错误提示输出到error.log文件中,就不会再控制台显示了,控制台就当做没有任何异常产生了,不会报任何错误信息,即使有异常产生。
3)e.printStackTrace()才是打印错误提示的关键。
3.hashmap是可以转换为string的,hmap可以进行日志打印。hashmap有hashmap.toString()方法。

讲一讲java异常时怎么回事

原文:http://www.cnblogs.com/panxuejun/p/6430412.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!