先直接上程序,再讲解
namespace ObjectAppTest
{
class A
{
public virtual void F()
{
Console.WriteLine("A.F");
}
}
class B:A
{
new public void F()
{
Console.WriteLine("B.F");
}
}
class test
{
static void Main(string[] args)
{
B b = new B();
A a = b;
a.F();
b.F();
}
}
}
首先注意class A 中的方法 public virtual void F()和class B 中的方法 new public void F()。
当在执行B b = new B()后,系统为b开辟了一段内存空间。这时候,对象b就指向实在存在的空间。
然后执行A a = b;把b对象所指向的地址赋个类型为A的对象名。此时,a和b指向同一段存储空间
执行a.F();编译时,检测到对象A中的方法为虚方法,编译器此时会执行早期绑定,即编译器此时会调用类A中的F()方法。
如果将Class B中new public void F()的关键字new改成override,编译器会实现后期绑定。这也正好说明多态性的特点。
namespace ObjectAppTest
{
class A
{
public virtual void F()
{
Console.WriteLine("A.F");
}
}
class B:A
{
new public void F()
{
Console.WriteLine("B.F");
}
}
class test
{
static void Main(string[] args)
{
B b = new B();
A a = b;
a.F();
b.F();
}
}
}
首先注意class A 中的方法 public virtual void F()和class B 中的方法 new public void F()。
当在执行B b = new B()后,系统为b开辟了一段内存空间。这时候,对象b就指向实在存在的空间。
然后执行A a = b;把b对象所指向的地址赋个类型为A的对象名。此时,a和b指向同一段存储空间
执行a.F();编译时,检测到对象A中的方法为虚方法,编译器此时会执行早期绑定,即编译器此时会调用类A中的F()方法。
如果将Class B中new public void F()的关键字new改成override,编译器会实现后期绑定。这也正好说明多态性的特点。