<strong><span style="font-size:24px;">多态</span></strong>
<span style="font-size:24px;color:#ff0000;">如果派生类中定义的方法与基类的方法同名,则在c#语言推荐的设计中,该方法要么修饰为new,要么修饰为override</span>
<strong><span style="font-size:24px;"><span style="color:#ff0000;">new</span><strong><span style="font-size:24px;">代表这是一个派生类中的新的方法,仅仅只是和基类中的某个方法同名而已,</span></strong></span></strong>
<strong><span style="font-size:24px;"><span style="color:#ff0000;">override</span>代表重写,一旦派生类中的某个方法修饰为override,则基类中对应的同名方法必须修饰为virtual(该方法是虚方法)abstract(该方法为抽象方法)或override(同时存在上一个基类)</span></strong>
<strong><span style="font-size:24px;">
</span></strong>
<strong><span style="font-size:24px;">
</span></strong>
<strong><span style="font-size:24px;">代码示例如下:</span></strong>
<strong><span style="font-size:24px;">using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ConsoleApplication1
{
class Base {
public virtual void method() {//virtual代表此方法为虚方法
Console.WriteLine("这是base里的method方法");
}
}
class derive : Base {//derive继承Base
public new void method() {//method方法为new 代表只是同名方法,并没有覆盖
Console.WriteLine("这是derive的method方法");
}
}
class Class1
{
static void Main()
{
Base b = new derive();
b.method();//父类对象指向子类示例,只能访问子类继承的方法</span></strong>
<strong><span style="font-size:24px;"> derive de = new derive();
((Base)de).method();
}
}
}
</span></strong>
<strong><span style="font-size:24px;">运行结果:
这是base里的method方法
这是base里的method方法
</span></strong>
如果将new改为override,则b.method的结果为derive的method方法,因为此时base里的method的方法已被覆盖