C#的多态(四)
using System ;
class A
{
public void F( ) { Console.WriteLine("A.F") ; }
public virtual void G( ) { Console.WriteLine("A.G") ; }
}
class B: A
{
new public void F( ) { Console.WriteLine("B.F") ; }
public override void G( ) { Console.WriteLine("B.G") ; }
}
class Test
{
static void Main( )
{
B b = new B( ) ;
A a = b;
a.F( ) ;
b.F( ) ;
a.G( ) ;
b.G( ) ;
}
}[/quote]
例子中,A 类提供了两个方法:非虚的F 和虚方法G 。类B 则提供了一个新的非虚的方法F, 从而覆盖了继承的F; 类B 同时还重载了继承的方法G 。那么输出应该是:A.F B.F B.G B.G
注意到本例中,方法a.G( ) 实际调用了B.G,而不是A.G,这是因为编译时值为A,但运行时值为B ,所以B 完成了对方法的实际调用。
class A
{
public void F( ) { Console.WriteLine("A.F") ; }
public virtual void G( ) { Console.WriteLine("A.G") ; }
}
class B: A
{
new public void F( ) { Console.WriteLine("B.F") ; }
public override void G( ) { Console.WriteLine("B.G") ; }
}
class Test
{
static void Main( )
{
B b = new B( ) ;
A a = b;
a.F( ) ;
b.F( ) ;
a.G( ) ;
b.G( ) ;
}
}[/quote]
例子中,A 类提供了两个方法:非虚的F 和虚方法G 。类B 则提供了一个新的非虚的方法F, 从而覆盖了继承的F; 类B 同时还重载了继承的方法G 。那么输出应该是:A.F B.F B.G B.G
注意到本例中,方法a.G( ) 实际调用了B.G,而不是A.G,这是因为编译时值为A,但运行时值为B ,所以B 完成了对方法的实际调用。
浙公网安备 33010602011771号