代碼一:
class A {
public String show(D obj){
return ("A and D"); }
public String show(A obj){
return ("A and A"); }
}
class B extends A{
public String show(B obj){
return ("B and B"); }
public String show(A obj){
return ("B and A"); }
}
class C extends B{}
class D extends B{}
A a1 = new A();
A a2 = new B();
B b = new B();
C c = new C();
D d = new D();
System.out.println(a2.show(b)); //①
System.out.println(a2.show(c)); //②
代碼二:
class A {
public void MethodA(){...}
public virtual void MethodB(){...}
}
class B extends A{
public new void MethodA(){...}
public override void MethodB(){...}
}
//其中,B類重寫了A類的普通方法MethodA,也重寫了A類的虛擬方法MethodB,則:
A a = new B();
a.MethodA();//③ 將會調用A類的MethodA方法
a.MethodB();//④ 將會調用B類的MethodB方法
問題1:代碼一:
①②運行的結果都是調用B類的show(A obj),輸出B and A。不太明白為什麼會返回這個,我自己的理解是①是父類引用指向子類對象,因為a2是A類型,所以先從A類的方法裡看,A類的方法裡沒有show(B obj) 所以去B類裡找方法,又因為B類裡的show(B obj)是重載,而show(A obj)是重寫,重載的部分不能調用,所以只能調用show(A obj)。這樣的理解對嗎?
問題2:代碼二:
為什麼代碼二中③將會調用A類的MethodA方法,④將會調用B類的MethodB方法?重寫之後不是應該都調用B類裡的MethodA和MethodB方法嗎?有人提到是因為普通方法和虛方法在編譯和運行時的綁定問題,普通方法和虛方法又是什麼?
代碼一中:A中沒有show(B,obj),而B是A的子類對象調用的是A中show(A obj),而因為A是用B構造的,且B中重寫了A中的show(A obj),因此調用的時候回調用B中的show(A obj),千萬不要想當然的理解為A就是B對象,然後調用B的show(B obj);還有就是
代碼二中:你貼的是C++的吧,java中用abstract類修飾虛函數,修改成這樣:
abstract class E {
public void MethodA() {
System.out.println("A-->MethodA");
}
public abstract void MethodB();
}
class F extends E {
public void MethodA() {
System.out.println("B-->MethodA");
}
public void MethodB() {
System.out.println("B-->MethodB");
}
}
測試代碼如下:
E e = new F();
e.MethodA();
e.MethodB();
輸出結果如下:
B-->MethodA
B-->MethodB
因此跟你說的結果不一致,因為B已經重寫了A的MethodA方法,調用的時候還是會調用B的MethodA方法。MethodB沒有問題。