Test.java
public class Test {
public void go(){
System.out.println("Test go");
}
}Test2.java
public class Test2 extends Test {
public void go(){
System.out.println("Test 2 go");
}
public void back(){
System.out.println("Test 2 back");
}
}
class Demo{
public static void main(String[] args) {
Test t=new Test2();
t.go(); // Output : "Test 2 go"
t.back(); //Compile time error.
}
}我读到了关于堆栈溢出的一些问题,但是我不理解SuperClass s=new SubClass();的含义。在输出中,如果测试对象可以访问Test2的Test2方法,那么为什么不能访问back()方法。
发布于 2016-09-28 11:37:11
这是一个多态性的例子,这意味着我们可以使用超级类型的引用来引用子类型对象。
没有为back()类型定义Test方法。您正在对无效的back()类型变量调用Test方法。当你宣布
Test t = new Test2();t的引用变量Test。Test2类型的对象。在输出中,如果可以访问Test2的go()方法,那么为什么它不能访问back()方法。
由于t是Test类型的,它只能知道在Test类中定义的方法。它不能知道在子类Test2中定义的方法。
关于你在评论中的问题,
t.go()时,编译器正在考虑调用来自Test类的go()方法。在编译时,不知道要创建哪个对象。Test t = new Test2();在运行时创建Test2对象,该对象反过来从Test2调用go()方法,因为它正在从Test重写go()。你真该看看关于编译时间多态性和运行时多态性的书
https://stackoverflow.com/questions/39746277
复制相似问题