(1)任何一种程序设计语言设计的程序在运行时都可能出现错误。
(2)捕获错误最理想的是在编译期间,但有的错误只有在运行时才会发生。
(3)对于这些错误,一般有两种解决方法:
- 遇到错误就终止程序运行;
- 由程序员在编写程序时,就考虑到可能出现的错误,并进行错误的检测、错误的提示以及错误的处理;
那么什么是编译,什么是运行呢?
编译:又分为编译和链接两个过程。编译是将源文件转换为机器可识别的二进制文件。链接是将这些二进制文件组合成系统可以执行的可执行文件。
运行:将编译出来的可执行程序放在系统中进行运行。
Java异常:在java语言中,将程序执行中发生的不正常情况称为异常。
java中的异常用于处理非预期的情况,如文件没找到、网络错误、非法的参数等。
java程序运行过程中的异常可分为两类:
- Error:JVM系统内部错误、资源耗尽等严重情况;
- Exception:其它因编程原因或偶然的外在因素导致的一致性问题,例如空指针访问、试图读取不存在的文件、网络连接中断等。
异常处理机制:
- 在编写程序时,经常要在可能出错误的地方加上检测的代码;
- java异常处理:java采用异常处理机制,将异常处理的程序代码集中在一起,与正常的程序代码分开,使得程序简洁,并利于维护;
说明:
- java提供的是异常处理的抓抛模型;
- java程序的执行过程中若果出现异常,会自动生成一个异常类对象,该异常对象将被提交给java运行时系统,这个过程称为抛出异常;
- 如果在一个方法内抛出异常,该异常会被抛到调用的方法中,如果异常没有在调用方法中处理,他继续被抛给这个调用方法的调用者。这个过程会一直持续下去,直到异常被处理。这一个过程被称为捕获异常;
- 如果一个异常回到main()方法,并且main()也不处理,则程序运行终止;
- 程序员通常只能处理Exception,而对Error无能为力;
try{ //需要判断是否出现异常的语句 }catch(Exception e){ //捕获异常 }finally{ //无论是否出现异常,都会运行这里的代码 }
注意:如果有多个catch,在捕获到前面的异常后,后面的就不会再捕获了。
声明抛出异常
- 声明抛出异常是java中处理异常的第二种方式;
- 如果一个方法可能生成某种异常,但是并不能确定如何处理这个异常,则此方法应显示地声明抛出异常,表明该方法将不对这些异常进行处理,由该方法的调用者进行处理。
- 在方法中声明throws子句可以声明抛出异常的列表,throws后面的异常类型可以是方法中产生的异常类型,也可以是它的父类;
- 举例:public void readFile(String file) throws FileNotFoundException{
FileInputStream fis = new FileInputStream(file);
}
package myjava; public class Test3 { public static void main(String[] args) { B b = new B(); try { b.test(); }catch(Exception e){ e.printStackTrace(); } } } class B{ int i; public void test() throws Exception{ B b = null; System.out.println(b.i); } }
输出:
注意:当父类方法抛出异常,子类方法继承父类对该方法进行重写时,也需要抛出异常,同时抛出的异常范围不能比父类的大。
人工抛出异常:
- java异常类对象除在程序执行的过程中出现异常时由系统自动生成并抛出,也可根据人工创建并抛出;
- 首先要生成异常类对象,然后通过throw语句实现抛出操作;
- 可以抛出的异常必须是throwable或其子类的实例;
package myjava; public class Test3 { public static void main(String[] args) { B b = new B(); try { b.test(200); }catch(Exception e){ e.printStackTrace(); } } } class B{ int age; public void test(int age) throws Exception{ if (age>=0 && age <= 100) { System.out.println("合法"); }else { throw new Exception("年龄不合法"); } } }
输出:
创建用户自定义异常类:用户自定义的异常类必须继承现有的异常类
package myjava; public class Test3 { public static void main(String[] args) { B b = new B(); try { b.regist(-1); }catch(Exception e){ e.printStackTrace(); } } } class B{ public void regist(int num) throws Exception{ if (num<0) { throw new MyException("人数不能为负值",3); }else { System.out.println("登记人数"+num); } } } class MyException extends Exception{ private int idnumber; public MyException(String message,int id) { super(message); this.idnumber = id; } public int getId() { return idnumber; } }
输出:
然后就可以抛出异常:
package myjava; public class Test3 { public static void main(String[] args) { B b = new B(); try { b.message(); }catch(Exception e){ e.printStackTrace(); } } } class B{ public void regist(int num) throws Exception{ if (num<0) { throw new MyException("人数不能为负值",3); }else { System.out.println("登记人数"+num); } } public void message() throws Exception { try { regist(-1); }catch (MyException e){ System.out.println("登记失败,出错种类"+e.getId()); } System.out.println("本次登记结束"); } } class MyException extends Exception{ private int idnumber; public MyException(String message,int id) { super(message); this.idnumber = id; } public int getId() { return idnumber; } }
输出: