C#中调用父类的构造方法和成员
C#中使用的关键字是base,但用法不完全相同。
1. 调用父类的构造方法
// 父类
public class Father
{
public Father(String name)
{
this.name = name;
}
private String name;
}
// 子类
public class Son:Father
{
public Son(String name)
: base(name)
{
}
}
注意:
如果没有第14行“:base(name)”,编译器将报告错误:“Father”不包含采用“0”参数的构造函数。因为默认隐式调用
父类不带参数的构造方法,而Father类没有不带参数的构造方法。所以此时需要像第14行那样显示调用父类构造方法。
2. 调用父类的成员
// 父类
public class Father
{
public String name = "小头爸爸";
public void TellName()
{
Console.WriteLine("My name is {0}.",name);
}
}
// 子类
public class Son:Father
{
public new String name = "大头儿子";
public new void TellName()
{
Console.Write("Father Told: ");
base.TellName();
Console.WriteLine("My Father's name is {0}",base.name);
Console.WriteLine("My name is {0}.", name);
}
}
如果不加第13行和第14行的关键字new,编译器将产生2个警告,但不影响程序的运行。因为子类隐藏了父类的成员。
如果第4行和第13行的name成员是private,会少产生一个警告。
3. 子类的子类调用父类中的隐藏成员
一般情况,在调用父类成员时子2代和子1代没什么区别。但如果子1代隐藏父类成员,情况就会不同。
像上面的情况,Son隐藏了父类的成员变量name和成员方法TellName(),如果再有一个类Grandson继承Son,那Grandson调用
Father类中被隐藏的成员时要像这样:
// 子类的子类
public class Grandson : Son
{
public new String name = "大头孙子";
public new void TellName()
{
Father f = this as Father;
Console.WriteLine("My Grandpa's name is {0}", f.name);
Console.WriteLine("My Father's name is {0}", base.name);
Console.WriteLine("My name is {0}.", name);
}
}
也可以使用强制转换,第8行不要,第9行的“f.name”换成“((Father)this).name”。但是不能使用base进行强制转换。