前言
我们编译运行程序出错的时候,编译器就会抛出异常。抛出异常要比终止程序灵活许多,这是因为
的Java提供了一个“捕获”异常的的处理器(处理器)对异常情况进行处理。
如果没有提供处理器机制,程序就会终止,并在控制台上打印一条信息,给出异常的类型.L
比如:使用了NULL引用或者是数组越界等。
异常有两种类型:未检查异常和已检查异常对于已检查异常,处理器器将会检查是否提供了处理器。
然而有许多の异常,如:访问null引用,都属于未检查异常。编译器不会查看是否为这些错误提供了处理器。毕竟,应该用严谨的态度来对待写代码,依次避免这些错误的发生,而不是将精力花在编写异常处理器上。
废话少说,show coder:
/ * try catch:自己处理异常
* try {
*可能出现异常的代码
*} catch(异常类名A e){
*如果出现了异常类A类型的异常,那么执行该代码
*} ...(catch可以有多个)
* finally {
*最终肯定必须要执行的代码(例如释放资源的代码)
*}
*代码执行的顺序:
* 1.try内的代码从出现异常的那一行开始,中断执行
* 2.执行对应的catch块内的代码
* 3.继续执行try catch结构之后的代码
*注意点:
* 1.如果catch内的异常类存在子父类的关系,那么子类应该在前,父类在后
* 2。如果最后中有返回语句,那么最后返回的结果肯定以最终中的返回值为准
* 3。如果最后语句中有回报,那么没有被处理的异常将会被吞掉
*重写的注意点:
* 1.儿子不能比父亲的本事大
* 2.儿子要比父亲开放
* 3.儿子不能比父亲惹更大的麻烦(子类的异常的类型不能是父类的异常的父类型)
*异常类Api:
* 1。的getMessage():获取异常描述信息字符串
* 2。的toString():返回异常类的包路径和类名和异常描述信息字符串 * 3。的printStackTrace():除了打印的toString的信息外,还要打印堆栈信息
* /
上面一段注释来自网上这位博主的,觉得写的很好,传送门地址https://blog.csdn.net/wanghuiwei888/article/details/78818203
package Bird; import java.io.FileNotFoundException; import java.io.FileReader; // public class TestYc { public static void main(String[] args) { try{ FileReader fr = new FileReader("c:/abc.txt"); } catch (FileNotFoundException e) { //打印输出异常 e.printStackTrace(); } Mother mother = new Mother(); mother.bbb(); //1.編譯時異常 //讀取該路徑"c:/abc.txt"下的文件 /* try { FileReader fr = new FileReader("c:/abc.txt"); }catch(FileNotFoundException e) { //打印输出异常 e.printStackTrace(); }*/ int [] arr = new int[] {1,2,3}; System.out.println(arr[2]); } } class Mother { private Boy b = null; // 构造器 public Mother() { b = new Boy(); } public void bbb() { // TODO Auto-generated method stub //调用带有异常的方法 try { b.aaa(); }catch(FileNotFoundException e) { e.printStackTrace(); } } } class Boy { // throws 把异常抛给上层的调用者 public void aaa() throws FileNotFoundException{ FileReader fr = new FileReader("c:/abc.txt"); } }
运行截图,文件打开不存在:
正常运行截图:
总结
到此这篇关于Java中try catch基本用法的文章就介绍到这了,更多相关Java中try catch用法内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!