C#中类的继承问题04

简介:
using System;
using System.Collections.Generic;
using System.Text;
namespace 类的继承问题04
{
    class Program
    {
        static void Main(string[] args)
        {
            A Aa;  //定义一个引用变量 虽然抽象类不可以实例化,但可以声明抽象类的引用变量
            C Ca = new C();
            Aa = Ca;
            Aa.AbstractMethod01(); //调用C类实现的AbstractMethod01()方法,这个是通过多态实现的
            Aa.NotAbstractMethod();//调用自身的非抽象方法
            B Ba;  //定义一个引用变量  虽然抽象类不可以实例化,但可以声明抽象类的引用变量
            Ba = (B)Aa;
            Ba.AbstractMethod01();//调用C类实现的AbstractMethod01()方法,原因是多态
            Ba.AbstractMethod02();//调用C类实现的AbstractMethod02()方法,原因是多态

            Console.ReadKey();
        }
    }
    abstract class A
    {
        public abstract void AbstractMethod01();//抽象方法,没有主体,结尾以分号结束
        public abstract void AbstractMethod02();//抽象方法,没有主体,结尾以分号结束
        public void NotAbstractMethod()
        {
            Console.WriteLine("抽象类A中的非抽象方法");
        }
    }
    abstract class B : A //派生自抽象类A的B可以不实现其抽象方法,但要保证B类也必须是抽象的才行
    {
        public override void AbstractMethod01()   //,派生类B中实现了基类A中的一个抽象方法,另一个不实现是可以的
        {                                         //也就是说,派生类可以不完全实现抽象基类的抽象方法,此时这个派生类必须也是抽象的
            Console.WriteLine("B类实现的抽象方法01");
        }
    }
    class C : B    //最中实现了A类中的抽象方法,终于冲破了“抽象诅咒”
    {
        public override void AbstractMethod01()
        {
            //throw new Exception("The method or operation is not implemented.");
            base.AbstractMethod01();       //通过base可以调用抽象基类中的抽象方法,此时是调用基类B中的AbstractMethod01()方法
            Console.WriteLine("C类实现的抽象方法01");
        }
        public override void AbstractMethod02()
        {
            //throw new Exception("The method or operation is not implemented.");]
            Console.WriteLine("C类实现的抽象方法02");
        }
    }

    abstract class F : A  //虽然F类派生自抽象类A,但它可以一个也不实现A中的抽象方法 
    {                     //但要保证F是抽象类
    }
    class E : F
    {
        public override void AbstractMethod01()
        {
            Console.WriteLine("E类实现的抽象方法01");
        }
        public override void AbstractMethod02()
        {
            Console.WriteLine("E类实现的抽象方法02");
        }
    }
}
 







本文转自terryli51CTO博客,原文链接:http://blog.51cto.com/terryli/512743 ,如需转载请自行联系原作者



相关文章
C# 继承类中(父类与子类)构造函数的调用顺序
C# 继承类中(父类与子类)构造函数的调用顺序
|
编译器 C#
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
316 65
|
设计模式 自然语言处理 C#
C#OOP之八 继承 接口和抽象类
C#OOP之八 继承 接口和抽象类
135 0
|
安全 C#
C# 面向对象编程的三大支柱:封装、继承与多态
【9月更文挑战第17天】在C#中,面向对象编程的三大支柱——封装、继承与多态,对于编写安全、可维护、可复用的代码至关重要。封装通过访问修饰符和属性保护数据;继承允许子类继承父类的属性和方法,实现代码复用和多态;多态则提高了代码的灵活性和通用性。掌握这三大概念能显著提升C#编程能力,优化开发效率和代码质量。
379 3
|
存储 C#
C# 一分钟浅谈:继承与多态性的实践
【9月更文挑战第2天】本文从基础入手,详细介绍了面向对象编程中继承与多态性的核心概念。通过 `Animal`、`Dog` 和 `Cat` 类的示例代码,展示了如何利用继承重用代码及多态性实现不同对象对同一方法的多样化响应,帮助读者更好地理解和应用这两个重要概念,提升面向对象编程能力。
230 4
C#中的类和继承
C#中的类和继承
187 6
|
存储 算法 C++
Hash与布隆过滤器
Hash与布隆过滤器
201 0
Hash与布隆过滤器
C# 继承、多态性、抽象和接口详解:从入门到精通
在 C# 中,可以将字段和方法从一个类继承到另一个类。我们将“继承概念”分为两类: 派生类(子类) - 从另一个类继承的类 基类(父类) - 被继承的类 要从一个类继承,使用 : 符号。 在以下示例中,Car 类(子类)继承了 Vehicle 类(父类)的字段和方法:
350 2
【从Java转C#】第四章:继承
【从Java转C#】第四章:继承
|
程序员 C#
C# 类实现接口(Interface) 多态 多继承
C# 类实现接口(Interface) 多态 多继承