C#中派生类调用基类构造函数用法分析
本文实例讲述了C#中派生类调用基类构造函数用法。分享给大家供大家参考。具体分析如下:
这里的默认构造函数是指在没有编写构造函数的情况下系统默认的无参构造函数
1、当基类中没有自己编写构造函数时,派生类默认的调用基类的默认构造函数
例如:
public class MyBaseClass { } public class MyDerivedClass : MyBaseClass { public MyDerivedClass() { Console.WriteLine("我是子类无参构造函数"); } public MyDerivedClass(int i) { Console.WriteLine("我是子类带一个参数的构造函数"); } public MyDerivedClass(int i, int j) { Console.WriteLine("我是子类带二个参数的构造函数"); } }
此时实例化派生类时,调用基类默认构造函数
2、当基类中编写构造函数时,派生类没有指定调用构造哪个构造函数时,会寻找无参的构造函数,如果没有则报错,另外无论调用派生类中的哪个构造函数都是寻找无参的那个基类构造函数,而非参数匹配。
例如:
public class MyBaseClass { public MyBaseClass(int i) { Console.WriteLine("我是基类带一个参数的构造函数"); } } public class MyDerivedClass : MyBaseClass { public MyDerivedClass() { Console.WriteLine("我是子类无参构造函数"); } public MyDerivedClass(int i) { Console.WriteLine("我是子类带一个参数的构造函数"); } public MyDerivedClass(int i, int j) { Console.WriteLine("我是子类带二个参数的构造函数"); } }
此时实例化派生类时则报错
3、基类中编写了构造函数,则派生类中可以指定调用基类的某个构造函数,使用base关键字。
例如
public class MyBaseClass { public MyBaseClass(int i) { Console.WriteLine("我是基类带一个参数的构造函数"); } } public class MyDerivedClass : MyBaseClass { public MyDerivedClass() : base(i) { Console.WriteLine("我是子类无参构造函数"); } public MyDerivedClass(int i) : base(i) { Console.WriteLine("我是子类带一个参数的构造函数"); } public MyDerivedClass(int i, int j) : base(i) { Console.WriteLine("我是子类带二个参数的构造函数"); } }
此时实例化派生类时使用的带一个参数的构造函数时,则不会报错,因为他指定了基类的构造函数。
4、如果基类中的构造函数不含有无参构造函数,那么派生类中的构造函数必须全部指定调用的基类构造函数,否则出错
例如
public class MyBaseClass { public MyBaseClass(int i) { Console.WriteLine("我是基类带一个参数的构造函数"); } } public class MyDerivedClass : MyBaseClass { public MyDerivedClass() { Console.WriteLine("我是子类无参构造函数"); } public MyDerivedClass(int i) : base(i) { Console.WriteLine("我是子类带一个参数的构造函数"); } public MyDerivedClass(int i, int j) { Console.WriteLine("我是子类带二个参数的构造函数"); } }
此时编译将不能通过
希望本文所述对大家的C#程序设计有所帮助。
最新评论