现在的位置: 首页 > 综合 > 正文

继承、多态性、重载的原理以及实例

2013年01月23日 ⁄ 综合 ⁄ 共 2445字 ⁄ 字号 评论关闭

简介:继承、多态性、重载

本文通过整合MSDN和网上各种资料,写出的一些自己的心得体会

一、  继承

新类(即派生类)将获取基类的所有非私有数据和行为以及新类为自己定义的所有其他数据或行为。因此,新类具有两个有效类型:新类的类型和它继承的类的类型

1、 继承C#中的类:C#不支持多重继承C#类始终继承自一个基类(如果未在声明中指定一个基类,则继承自System.Object)。

派生类继承基类的语法如下: using System; public class Person { //这是基类 } public class Student:Person { //这是派生类 } 注:派生类继承基类时用“:”符号连接,派生类继承基类的所有非私有成员变量和方法。

2、 调用基类的构造函数:如果对类没有定义显式构造函数,则编译器将提供默认的构造函数,以初始化这些类的成员字段。但是,如果显式添加了构造函数,就可以有效控制整个构造过程。

示例: using System; namespace Jicheng {

 //基类 public class Person { public string  _name; public uint  _age;

//基类的构造函数 public Person(string name,uint age) { this._name = name; this._age = age;   

//打印输出 Console.WriteLine(_name); Console.WriteLine(_age); } }

 //派生类 public class Student:Person { private uint _id; }

//派生类构造函数并调用基类构造函数用“:base public Student(string name,uint age uint id):base(name,age) { this._id = id;

//打印输出 Console.WriteLine(_id); } }

  public class Exercise { [STAThread] static void Main(string[] args) { //构造 Student Student objstudent=new Student(XYZ,45,001); } } }

注:派生类通过使用:base()语法可以显式调用基类的构造函数。在必要的情况下,可以利用它来初始化字段。

二、  继承的调用顺序

1.     先调用构造函数,再调用其他类或者方法。有父类先调用父类,接着是子类以及孙类。

2.     有父子孙类,先调用父类,再调用子类、最后调用孙类。例如父类:A B:A C:B;调用C时,AB的构造函数都要被调用。

 

三、  多态性

通过多态性,达到什么样一个目的?同一操作作用于不同(基类以及其派生出来的任何类)实例,不同的类将进行不同的解释、最后产生不同的执行结果。而你不需要知道该对象属于哪个类。

 

定义:通过继承,一个可以用作多种类型:可以用作它自己的类型、任何基类型,或者在实现接口时用作任何接口类型。这称为多态性。C# 中的每种类型都是多态的。类型可用作它们自己的类型或用作 Object 实例,因为任何类型都自动将 Object 当作基类型。

当派生类从基类继承时,它会获得基类的所有方法、字段、属性和事件。若要更改基类的数据和行为,您有两种选择:可以使用新的派生成员替换基成员,或者可以重写虚拟的基成员

1.             使用新的派生成员替换基类的成员需要使用 new 关键字。如果基类定义了一个方法、字段或属性,则 new 关键字用于在派生类中创建该方法、字段或属性的新定义。new 关键字放置在要替换的类成员的返回类型之前

C#

public class BaseClass

{

    public void DoWork() { }

    public int WorkField;

    public int WorkProperty

    {get { return 0; }}

}

 

public class DerivedClass : BaseClass

{

    public new void DoWork() { }

    public new int WorkField;

    public new int WorkProperty

    {get { return 0; }}

}

 

使用 new 关键字时,调用的是新的类成员而不是已被替换的基类成员。这些基类成员称为隐藏成员。如果将派生类的实例强制转换为基类的实例,就仍然可以调用隐藏类成员。例如:

C#

DerivedClass B = new DerivedClass();

B.DoWork();  // Calls the new method.

 

BaseClass A = (BaseClass)B;

A.DoWork();  // Calls the old method.

 

2.             为了使派生类的实例完全接替来自基类的类成员,基类必须将该成员声明为虚拟的。这是通过在该成员的返回类型之前添加 virtual 关键字来实现的。然后,派生类可以选择使用 override 关键字而不是 new,将基类实现替换为它自己的实现。例如:

C#

public class BaseClass

{

    public virtual void DoWork() { }

    public virtual int WorkProperty

    {

        get { return 0; }

    }

}

public class DerivedClass : BaseClass

{

    public override void DoWork() { }

    public override int WorkProperty

    {

        get { return 0; }

    }

}

 

字段不能是虚拟的只有方法、属性、事件和索引器才可以是虚拟的。当派生类重写某个虚拟成员时,即使该派生类的实例被当作基类的实例访问,也会调用该成员。例如:

C#

DerivedClass B = new DerivedClass();

B.DoWork();  // Calls the new method.

抱歉!评论已关闭.