1.格式
除方法的声明外,可以使用"throws 异常对象"来处理编译类型异常.
如public void test () throws 异常类型1,异常类型二...{
//编译时可能产生的异常.
}
2.是否真正处理了异常
(1). 从编译是否能通过的角度来看,看作为给出了要是出现了异常的解决方法,此时编译通过.
(2). 从另个角度来看,该方案只是将异常上抛给了调用者,调用者仍然需要考虑如何解决异常,故该方案并没有实际解决问题.
3.(联动)方法的重写
在方法的重写中,要求子类重写的方法throws的异常类型可以是父类被重写方法的异常类型相同,也可以是其子类.
举例 : IOException是FileNotFoundExcetion的父类.
class abstract Father throws IOException {
public abstract void method() {
//抛出IOException的代码,此处省略
}
}
class Son throws FileNotFountException {
public void method() {
//抛出FileNotFoundException异常的代码,此处省略.
}
}
父类的引用指向子类的对象,此时编译类型是Person,编译时期p.method()抛出的是IOException异常对象,故catch括号内捕获的是IOException异常对象.但运行阶段调用的是子类的method(),故抛出的是FileNotFoundException异常对象.如果catch语句内为IOException异常对象,相当于IOException e =new FileNotFoundException() ;此时再次体现多态性.如果catch语句中是IOException异常类的父类(如Exception),则违反了多态性.
Father p =new Son();
try{
p.method();
} catch (IOException e){
System.out.println(e.printStackException);
}
4.throw手动抛出异常对象
java中异常对象的生成方式有两种 :
(1). 一种是JVM自动生成.程序运行过程中,JVM检查代码出了问题,针对该代码,在后台自动创建一个对应异常类型的类的异常对象.
(2). 另一种是使用throw手动抛出 : throw new 异常类型(实参列表).
5.使用场景
在实际开发中,如果出现不满足具体场景的代码问题,可以手动throw抛出指定类型的异常.
//test03抛出的异常抛给主函数,此时主函数必须对异常进行捕获
public static void main(String[] args) {
try {
test03();
} catch (Exception e) {
e.printStackException;
}
}
//test01抛出的异常对象抛给了调用者test03
public void test03() throws Exception {
test01();
}
public void test01() throws Exception {
//手动抛出异常对象
throw new Exception();
}
//可以try-catch-finally捕获,也可以将异常抛给调用者,
//调用者要么再抛给调用者,要么try-catch-finally捕获异常
public void test02() {
try {
throw new Exception();
} catch(Exception e) {
e.printStackTrace();
}
}