在C#中理解继承与多态的实战应用
1.继承的概念
继承是使用已存在的类的定义作为基础建立新类的技术,新类的定义可以增加新的数据或新的功能,也可以用已存在的类的功能。
为了提高软件模块的可复用性和可扩充性,以便提高软件的开发效率,我们总是希望能够利用前人或自己以前的开发成果,同时又希望在
自己的开发过程中能够有足够的灵活性,不拘泥于复用的模块。C#这种完全面向对象的程序设计语言提供了两个重要的特性--
继承性inheritance 和多态性polymorphism。
继承是面向对象程序设计的主要特征之一,它可以让您重用代码,可以节省程序设计的时间。继承就是在类之间建立一种相交关系,使得
新定义的派生类的实例可以继承已有的基类的特征和能力,而且可以加入新的特性或者是修改已有的特性建立起类的新层次。
现实世界中的许多实体之间不是相互孤立的,它们往往具有共同的特征也存在内在的差别。人们可以采用层次结构来描述这些实体之间的
相似之处和不同之处。
在C#中,如果一个类后面通过冒号又跟了另外一个类,那么我们就称冒号前面的类
为子类,冒号后面的类为父类。这种书写类的方式放映出来的关系就称为类的继承关系。
子类:派生类
父类:基类或者超类
4.满足什么条件的类可以使用继承??
解析:满足is a关系的两个类可以使用继承。
案例:经理is a a 员工
程序员 is a 员工
学生 is a Person
5.如果new一个子类对象,那么有如下执行流程
01.先定位到子类对应构造函数,没有执行子类的方法体
02.转向了父类的无参构造函数,执行父类构造方法体
03.转向了子类的方法体继续执行。
点题的话:如果在子类构造中,没有使用base显示调用父类的构造,那么系统也会自动调用父类的无参构造
01.base代表父类对象,如果base():调用父类的构造函数
02.base代表的是方法调用,是不需要参数类型的
6.通过base调用父类构造函数注意点
解析:01.通过base调用父类构造函数只能书写在子类的构造后
02.通过base调用父类构造函数参数顺序和父类的构造参数一致
7.注意:方式一:new Student("张靓颖",20);
和方式二:new Student
{
Name="张靓颖",Age=20
}区别?
解析:最终都能实现对类中的属性赋值。
但是赋值的原理不同,
方式一:直接调用该类的带参构造赋值。
01.先通过无参构造创建出类的对象
02.对象名.属性名的方式赋值
8.访问修饰符
public:在任何位置都可以访问,甚至是跨程序集都可以访问。
private:只能当前类的花括号中访问。
protected:只能在当前类,当前类的子类,子类的子类(孙子类)中可以访问。
7.注意:方式一:new Student("张靓颖",20);
和方式二:new Student
{
Name="张靓颖",Age=20
}区别?
解析:最终都能实现对类中的属性赋值。
但是赋值的原理不同,
方式一:直接调用该类的带参构造赋值。
01.先通过无参构造创建出类的对象
02.对象名.属性名的方式赋值
8.访问修饰符
public:在任何位置都可以访问,甚至是跨程序集都可以访问。
private:只能当前类的花括号中访问。
protected:只能在当前类,当前类的子类,子类的子类(孙子类)中可以访问。
9.继承的传递性
如果一个类B继承自类A,而类C又继承类B,那么类C也可以访问到类A中非私有成员
10.继承的单根性 (C#不支持多继承 Java也不支持多继承)
在很久很久以前,有一个叫C++的家伙,他是支持多继承的语言,突然有一天,10个程序员用多继承,有9个都用错了,后续的Java和C#语言因此不再支持多继承。
在C#中,一个类只能有一个父类,C#和Java都不支持多继承。要想使用多继承,那么请您使用接口。。
11.遍历窗体上所有的控件,判断是不是文本框
foreach(Control c in this.Controls)
{
if(c is TextBox)
{
((TextBox)c).Text="";
}
}
is a 判断一个对象是否是某个类型。
12.继承的价值
01.模拟现实世界的关系
02.便于重用和扩展已彻底测试的代码,且无需修改
03.结构更清晰
13.多态
不同的对象对于同一个操作,做出的响应不同,那么这种情况在面向对象编程中就称为多态
使用多态的目的?
解析:使用多态就是为了统一调用
14.实现多态三种方式:
方式一:通过虚方法实现多态
实现多态的步骤
01.在父类中通过virtual关键字定义一个虚方法
02.在子类中通过override关键字对父类中的虚方法进行重写
03.调用的时候,调用的是子类的方法
目前为止,我们学了两种:
第一种:虚方法实现多态
通过在普通类Person中用Virtual关键字定义虚方法SayHello(),然后在子类Student中通过override关键字对父类的SayHello()方法进行重写。
如下:
Student类
Teacher类
在Main方法中调用
下一篇: C++中的继承概念详解
推荐阅读
-
理解Oracle的listagg函数与Mysql的group_concat在实际应用中的差异与相似之处
-
iOS应用中的多态性:解释与理解
-
实战详解:Java包扫描在Jar包中的应用与实现
-
实战探索:Apache Hudi在流处理与批处理场景中的应用实例
-
深入理解分治算法在LeetCode实战中的应用:快速排序思维解析与算法沉淀
-
【摩尔线程+Colossal-AI强强联手】MusaBert登上CLUE榜单TOP10:技术细节揭秘 - 技术实力:摩尔线程凭借"软硬兼备"的技术底蕴,让MusaBert得以从底层优化到顶层。其内置多功能GPU配备AI加速和并行计算模块,提供了全面的AI与科学计算支持,为AI推理和低资源条件下的大模型训练等场景带来了高效、经济且环保的算力。 - 算法层面亮点:依托Colossal-AI AI大模型开发系统,MusaBert在训练过程中展现出了卓越的并行性能与易用性,特别在预处理阶段对DataLoader进行了优化,适应低资源环境高效处理海量数据。同时,通过精细的建模优化、领域内数据增强以及Adan优化器等手段,挖掘和展示了预训练语言模型出色的语义理解潜力。基于MusaBert,摩尔线程自主研发的MusaSim通过对比学习方法微调,结合百万对标注数据,MusaSim在多个任务如语义相似度、意图识别和情绪分析中均表现出色。 - 数据资源丰富:MusaBert除了自家高质量语义相似数据外,还融合了悟道开源200GB数据、CLUE社区80GB数据,以及浪潮公司提供的1TB高质量数据,保证模型即便在较小规模下仍具备良好性能。 当前,MusaBert已成功应用于摩尔线程的智能客服与数字人项目,并广泛服务于语义相似度、情绪识别、阅读理解与声韵识别等领域。为了降低大模型开发和应用难度,MusaBert及其相关高质量模型代码已在Colossal-AI仓库开源,可快速训练优质中文BERT模型。同时,通过摩尔线程与潞晨科技的深度合作,仅需一张多功能GPU单卡便能高效训练MusaBert或更大规模的GPT2模型,显著降低预训练成本,进一步推动双方在低资源大模型训练领域的共享目标。 MusaBert荣登CLUE榜单TOP10,象征着摩尔线程与潞晨科技联合研发团队在中文预训练研究领域的领先地位。展望未来,双方将携手探索更大规模的自然语言模型研究,充分运用上游数据资源,产出更为强大的模型并开源。持续强化在摩尔线程多功能GPU上的大模型训练能力,特别是在消费级显卡等低资源环境下,致力于降低使用大模型训练的门槛与成本,推动人工智能更加普惠。而潞晨科技作为重要合作伙伴,将继续发挥关键作用。
-
理解 if 与 whether:两者在英语中的差异与应用探讨
-
在Java中,理解锁方法(Lock): lock与tryLock的实战运用
-
在Node.js中轻松理解和应用JWT与Session的区别与用法
-
在 TypeScript 中:理解通用作用域、自动类型推断与多类型参数的应用