为何子类中的覆盖方法只能抛出和基类方法相同或者更少的异常
为何子类中的覆盖方法只能抛出和基类方法相同或者更少的异常?
我实在是笨,想不通,请各位指教!!!
[解决办法]
A a = new B();
a.test();
编译时调用 类A 中test(),抛出异常,
实际调用的是 类B 中的 test(),
如果类B中的 方法抛出了 更大的异常,这样就无法捕获了。
[解决办法]
多态性的考虑,比如下面这种写法的代码,一个抽象类,然后一个实现类:
abstract class Foo
{
abstract void hello();
}
class FooImpl extends Foo
{void hello()
{
}
}
我们用的时候,通常会这样用:
Foo f=new FooImpl();
f.hello();
如果FooImpl里实现的hello方法抛了异常,而Foo定义的hello实际没throws异常的,那上写这个调用方法,定义的f是Foo类型的,Foo类里的hello方法没异常,不是就冲突了吗?
不知这样你能理解不。
[解决办法]
import java.io.File;
public class Test{
public static void main (String[]args){
try{
File f = new File("D:\\test.txt");//NullPointerException
System.out.println(f.exists());//SecurityException
}catch(Exception e){
//输出异常[1]
}catch(NullPointerException ex){
//不再输出,因为异常已经被父异常捕获.[2]
}catch(SecurityException se){
//不再输出,因为异常已经被父异常捕获.[3]
}
//如果要正常输出异常,需要将[1]放在最后面,形如下面这样:
/*
try{
File f = new File("D:\\test.txt");//NullPointerException
System.out.println(f.exists());//SecurityException
}catch(NullPointerException ex){
}catch(SecurityException se){
}catch(Exception e){
//输出异常[1]
}
*/
}
}
因此,如存在接口A的方法am1抛出SQL异常,对于面向接口的编程来说,此类异常是可预见的,可以定制一些对应的异常捕获和处理方式。
如果一个实现类抛出SQL异常,或者SQL异常的子异常(如BatchUpdateException),那就是可以预期的,可以捕获并处理。
但如果实现类抛出的是IOException,不在SQLExcepton的范围,你无法预知,所以也是无法处理的。