[英]Object type confusion in Java
public class Test {
public static void main(String[] args){
B b=new B();
A a1=new A();
A a2=b;
a1=b;
a1.printDescription(); //which prints I'm B
a2.printDescription(); //which also prints I'm B
}
}
class A{
public void printDescription(){
System.out.println("I'm A");
}
}
class B extends A{
public void printDescription(){
System.out.println("I'm B");
}
}
经过搜索,我找到了Java polymorphism 中的 Confusion的解释,它说:“尽管 x 明确声明为类型 A,但它被实例化为类 B 的对象,因此我将运行 doIt() 方法的版本,即在 B 类中定义。”但是在我使用 A 类构造函数实例化对象 a 之后,它仍然打印“我是 B”,所以有人可以为我解释一下吗?
B b=new B(); // b refers to an object of class B
A a1=new A(); // a1 refers to an object of class A
A a2=b; // a2 refers to an object of class B
a1=b; // now a1 refers to an object of class B
给a1
和a2
都指定了引用b
,它引用了B
类的对象。 因此, printDescription
两个类都执行了B
类的printDescription
的实现,并且得到了这两个类的“ I'm B”输出。
a1=b;
b
是B
,您将其分配给a1
。 类型在编译时说什么都没有关系 。 重要的是运行它时的实际情况。 由于您为a1
分配了B
,因此它是一个B
逐行浏览:
B b=new B(); //b is a B
A a1=new A(); //a1 is an A, b is a B
A a2=b; //a1 is an A, b is a B, and a2 is the same B as b
a1=b; //a1, a2 and b are all references to the same B value
这是因为绑定晚了 。 您在这里有方法重写(派生的类实现了一个与基名称相同的方法)。 这导致将调用保存在变量引用而不是引用类型上的派生最多的类型方法,并将在运行时确定该方法。
例如:
//This is an A-type reference, referencing to a A-type object
A a = new A();
B b = new B();
//The A-type reference, is now referencing to the B-type object.
//The old, A-type object held will be set for garbage collection.
A a = b;
//This will call the mostly derived type referenced method (which is B),
//which prints "I'm B"
a.printDescription();
在代码a1中,a2和b是指向B实例的引用变量。首先创建一个对象A,如下所示:
A a1 = new A();
但后来您将其指定为“ b”
a1 = b
这就是为什么它从B类而不是从A类执行方法的原因
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.