C#中子类调用父类的构造方法
本文实例讲述了C#
中实现子类调用父类的方法,分享给大家供大家参考之用。具体方法如下:
public class Person
{
public Person()
{
Console.WriteLine("我是人");
}
}
public class Student : Person
{
public Student()
{
Console.WriteLine("我是学生");
}
}
在客户端通过子类无参构造函数创建子类实例。
class Program
{
static void Main(string[] args)
{
Student student = new Student();
Console.ReadKey();
}
}
输出结果:
我是人
我是学生
可见:通过调用子类无参构造函数创建子类实例,会默认调用父类无参构造函数。
如果把父类的无参构造函数去掉,会怎样呢?
–结果会报"Person不包含0个参数的构造函数
"错。
二、通过子类有参构造函数创建子类实例
再同时为子类和父类添加有参构造函数。
public class Person
{
public Person()
{
Console.WriteLine("我是人");
}
public Person(string name)
{
Console.WriteLine("我是人,我的名字叫{0}", name);
}
}
public class Student : Person
{
public Student()
{
Console.WriteLine("我是学生");
}
public Student(string name)
{
Console.WriteLine("我是学生,我的名字叫{0}", name);
}
}
在客户端通过子类有参构造函数创建子类实例。
Student student = new Student("小明");
Console.ReadKey();
输出结果:输出结果:
我是人
我是学生,我的名字叫小明
可见:通过调用子类有参构造函数,同样默认会调用父类无参构造函数。
三、在子类中明确指出调用哪个父类构造函数
以上,默认调用了父类的无参构造函数,但如何调用父类的有参构造函数呢?
–在子类中使用base
在子类Student
中的有参构造函数中使用base
,明确调用父类有参构造函数。
public class Student : Person
{
public Student()
{
Console.WriteLine("我是学生");
}
public Student(string name)
: base(name)
{
Console.WriteLine("我是学生,我的名字叫{0}", name);
}
}
客户端
Student student = new Student("小明");
Console.ReadKey();
输出结果:
我是人,我的名字叫小明
我是学生,我的名字叫小明
四、通过子类设置父类的公共属性
在父类Person
中增加一个Name
公共属性,并在父类的构造函数中对Name
属性赋值。
public class Person
{
public string Name { get; set; }
public Person()
{
Console.WriteLine("我是人");
}
public Person(string name)
{
this.Name = name;
Console.WriteLine("我是人,我的名字叫{0}", name);
}
}
在客户端:
Student student = new Student("小明");
Console.WriteLine("子类获取父类的Name属性值为{0}", student.Name);
Console.ReadKey();
输出结果:
我是人,我的名字叫小明
我是学生,我的名字叫小明
子类获取父类的Name属性值为小明
以上代码的执行路径是:
- →调用子类有参构造函数,并把该参数传值给父类有参构造函数
- →调用父类有参构造函数,并给父类公共属性
Name
赋值 - →子类实例调用父类的公共属性
其实,以上的做法在分层架构设计中已经得到了很好的使用。在分层架构中,通常会为所有的Repository
创建一个基类,在基类中设计一个代表当前Repository
的属性,并在基类的构造函数中为该属性赋值;最终,在创建子类Repository
实例时,在为基类的、代表当前Repository
的公共属性赋值。
在子类中,当父类通过base
拿到子类的参数时,还可以对该参数做一些处理,比如代表父类的base
把从子类拿到的参数转换成大写。
public class Student : Person
{
public Student()
{
Console.WriteLine("我是学生");
}
public Student(string name)
: base(ConvertToUpper(name))
{
Console.WriteLine("我是学生,我的名字叫{0}", name);
}
private static string ConvertToUpper(string name)
{
return name.ToUpper();
}
}
输出结果:
我是人,我的名字叫DARREN
我是学生,我的名字叫darren
子类获取父类的Name属性值为DARREN
总结:
①.通过子类无参构造函数创建子类实例,会默认调用父类的无参构造函数
②.通过子类有参构造函数创建子类实例,也会默认调用父类的无参构造函数
③.在子类构造函数中通过base关键字指明父类构造函数,当通过子类构造函数创建实例,会调用指明的、父类的构造函数
④.父类的公共属性可以通过子类来赋值,子类也可以获取到父类的公共属性
出处:https://blog.csdn.net/WuLex/article/details/88608458
关注我】。(●'◡'●)
如果,您希望更容易地发现我的新博客,不妨点击一下绿色通道的【因为,我的写作热情也离不开您的肯定与支持,感谢您的阅读,我是【Jack_孟】!
本文来自博客园,作者:jack_Meng,转载请注明原文链接:https://www.cnblogs.com/mq0036/p/16943439.html
【免责声明】本文来自源于网络,如涉及版权或侵权问题,请及时联系我们,我们将第一时间删除或更改!
posted on 2022-12-02 09:31 jack_Meng 阅读(3164) 评论(0) 编辑 收藏 举报