欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

c#继承与多态使用示例

程序员文章站 2024-02-15 23:31:52
继承和多态派生类具有基类所有非私有数据和行为以及新类自己定义的所有其他数据或行为,即子类具有两个有效类型:子类的类型和它继承的基类的类型。 对象可以表示多个类型的能力称为...

继承和多态

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

对象可以表示多个类型的能力称为多态性。

多态性示例

复制代码 代码如下:

public class parent
    {
        public parent() { }
        public void methoda()
        {
            console.writeline("调用methoda()");
        }
        public class child:parent
        {
            public child() { }

            public void methodb()
            {
                console.writeline("调用methodb()");
            }

        }
        class test
        {

            static void main(string[] args)
            {

                parent oparent = new parent();
                oparent.methoda();//ok 调用类型parent的成员方法
                //child ochild1 = (child)oparent;//运行错误
                child ochild=new child();
                ochild.methodb();//ok 调用派生类child的成员方法
                ochild.methoda();//ok 调用基类parent的成员方法
                parent oparent1 =(parent)ochild;
                oparent1.methoda();
                //oparent1.methodb();//编译出错,类型parent不存在方法methodb()
                console.readline();
                child ochild1 = (child)oparent1;
                ochild1.methodb();//ok 调用派生类child的成员方法
                ochild1.methoda();//ok 调用基类parent的成员方法
                console.readkey();

            }
        }

    }

在上例中,类child既有效的child,又是有效的parent。ochild可以作为类型child,因而具有child本身定义的方法methodb()和基类parent定义的方法methoda();同时,对象ochild也可以强制转换为child的基类parent的对象oparent。强制转换不会更改ochild对象的内容,但oparent对象作为类型parent,因而只具有类parent定义的方法methoda()。

将child强制转换为parent后,可以将该parent重新强制转换为child。并只有实际上是child实例的那些实例才可以强制转换为child,否则会产生运行错误:无法将类型为parent的对象强制转换为类型child。

继承的类型

c#包含两种继承类型:实现继承和接口继承。

现继承表示一个类型派生于一个基类型,派生类具有基类的所有非私有(非private)数据和行为。在实现继承中,派生类型的每一个方法采用基类型的实现代码,除非在派生类的定义中指定重写该方法的实现代码。实现继承一般用于增加现有类型的功能,或许多相关的类型共享一组重要的公共功能场合。

接口继承表示一个类型实现若干接口,接口仅包含方法的签名,故接口继承不继承任何实现代码。接口继承一般用于指定该类型具有某类可用的特性,例如,如果指定类型从接口system.idisposable中派生,并在该类中实现idisposable接口的清理资源的方法dispose(),则可以通过工通的机制调用该方法以清理资源。由于清理资源的方式特定于不同的类型,故在接口中定义通用的实现代码是没有意义的,接口即契约,类型派生于接口,即保证该类提供该接口规定的功能。