C# 类多态性
本文关键字:多态性 | 更新日期: 2023-09-27 18:37:27
为什么休耕代码的结果是:
A
类 A
类 A类
public class A {
public virtual void f() {
Console.WriteLine("Class A");
}
}
public class B : A {
public virtual void f() {
Console.WriteLine("Class B");
}
}
public class C : B {
public override void f() {
Console.WriteLine("Class C");
}
}
//...
static void Main(string[] args) {
A[] array = new A[3];
array[0] = new A();
array[1] = new B();
array[2] = new C();
for(int d = 0; d < 3; d++)
array[d].f();
}
这是因为virtual
不等于override
。通过使用关键字virtual
您实质上是创建新方法,该方法是虚拟的,但它对您的类(类 B)来说是新的,并且不会覆盖类的 A 方法。从 B 继承的类 C 不知道类的 A 方法 f(),因此需要 B.f() 来覆盖它。在 Main 方法中,您将创建一个仅存在 A.f() 方法的 A 类数组。如果需要帮助,
Class A
Class B
Class C
输出使用 override
而不是 B 类中的virtual
。
AAA 因为
A[] array = new A[3]; /*main reference to A object*/