Max*_*ler 36 java theory oop overloading
public class A {
public void f1(String str) {
System.out.println("A.f1(String)");
this.f1(1, str);
}
public void f1(int i, String str) {
System.out.println("A.f1(int, String)");
}
}
public class B extends A {
@Override
public void f1(String str) {
System.out.println("B.f1(String)");
super.f1(str);
}
@Override
public void f1(int i, String str) {
System.out.println("B.f1(int, String)");
super.f1(i, str);
}
}
public class Main {
public static void main(String[] args) {
B b = new B();
b.f1("Hello");
}
}
Run Code Online (Sandbox Code Playgroud)
我正在寻求这段代码输出:
B.f1(String)
A.f1(String)
A.f1(int, String)
Run Code Online (Sandbox Code Playgroud)
但我得到了:
B.f1(String)
A.f1(String)
B.f1(int, String)
A.f1(int, String)
Run Code Online (Sandbox Code Playgroud)
据我所知,在A.f1(String)中B"this"的上下文是B的实例.我可以选择执行新的B1().f1(String) - >(A)f1(String) - >(A)f1(int,String)?
这是一个理论问题,实际上解决方案显然是在A中实现f1(String)和f1(int,String)都会调用的私有函数.
谢谢你,
马克西姆.
maa*_*nus 19
我担心,这是不可能的,但有一个简单的解决方法:
public class A {
public void f1(String str) {
System.out.println("A.f1(String)");
privateF1(1, str);
}
private void privateF1(int i, String str) {
System.out.println("A.f1(int, String)");
}
public void f1(int i, String str) {
privateF1(i, str);
}
}
Run Code Online (Sandbox Code Playgroud)
Java中的重写方法是动态绑定的.即,对象的实际实例的类型决定了将要调用的内容.final
方法(不能被覆盖)和private
方法(不能被继承)是静态绑定的.
相比之下,在C++中,您必须明确地使函数virtual
获得相同的行为.