OOP三类继承的区别

OOP继承的区别提纲:

1. 普通类继承,并非一定要重写父类方法。2. 抽象类继承,如果子类也是一个抽象类,并不要求一定重写父类方法。如果子类不是抽象类,则要求子类一定要实现父类中的抽象方法。3. 接口类继承。如果是一个子接口,可以扩展父接口的方法;如果是一个子抽象类,可以部分或全部实现父接口的方法;如果子类不是抽象类,则要求子类一定要实现父接口中定义的所有方法。

1.抽象类继承

在定义类的前面加上关键字abstract,那么这个类就是抽象类了,

抽象类本身无法产生实例对象,而且抽象类包含了一个以上的抽象方法,这些方法只是提供函数名称,并没有定义如何具体实现,由继承的派生类实现,

派生类同时必须实现所有抽象类的方法,否则其本身将成为另外一个抽象类。

需要我们注意的一点是,当派生类重写抽象类的方法时,要使用override关键字来重写抽象类所定义的方法

抽象类只能被继承,不能被实例化,抽象类的抽象方法是虚方法

新建person类:

public abstract class Person
    {
        public abstract void show();
    }

public class Student : Person 
    {
        public override void show()
        {
            Console.WriteLine("我是老大!");
        }
    }

public class Manager : Person 
    {
        public override void show()
        {
            Console.WriteLine("我是管理员!");
        }
    }

另建一个Teacher类

class Teacher
    {
        public void tShow(Person person) 
        {
            person.show();
        }
    }

在Main方法实现:

static void Main(string[] args)
        {
            Teacher teacher = new Teacher();
            teacher.tShow(new Manager());
        }

2.接口类继承

类和接口继承

14.2定义接口

14.3接口的继承

 public static class Program
    {
        static void Main(String[] args) { 
           //-------------------------
            Console.WriteLine("---第一个例子---");
            BaseClass b = new BaseClass();
            b.fun1();
            b.fun2();
            ((Itest)b).fun1();
            ((Itest)b).fun2();
           //--------------------------
            Console.WriteLine("---第二个例子---");
            SonOne s1 = new SonOne();
            s1.fun1();
            s1.fun2();
            ((Itest)s1).fun1();
            ((Itest)s1).fun2();
          //----------------------------
            Console.WriteLine("---第三个例子---");
            b = new SonOne();
            b.fun1();
            b.fun2();
            ((Itest)b).fun1();
            ((Itest)b).fun2();
          //----------------------------
            Console.WriteLine("---第四个例子---");
            SonTwo s2 = new SonTwo();
            s2.fun1();
            s2.fun2();
            ((Itest)s2).fun1();
            ((Itest)s2).fun2();
          //----------------------------
            Console.WriteLine("---第五个例子---");
            b = new SonTwo();
            b.fun1();
            b.fun2();
            ((Itest)b).fun1();
            ((Itest)b).fun2();
        //----------------------------
            Console.ReadLine();
        }
    }
    public interface Itest {
        void fun1();
        void fun2();
    }
    //1.BaseClass必须实现Itest中的所有方法 fun1,fun2
    //2.应将接口方法标记为virtual,如果不显示标记,编译器会把它标记为virtual和sealed。这样派生类就无法重写接口方法了。
    //  派生类可以重新继承同一个接口,并提供自己的实现。
    internal  class BaseClass : Itest {
        //fun1将被标记为sealed,不能被重写
        public void fun1() {
            Console.WriteLine("BaseClass.fun1");
        }
        public virtual void fun2()
        {
            Console.WriteLine("BaseClass.fun2");
        }
    }
    internal class SonOne : BaseClass {
        //派生类无法重写基类方法fun1
        new public void fun1() {
            Console.WriteLine("SonOne.fun1");
        }
        //派生类可以重写基类方法fun2
        public override void fun2()
        {
            Console.WriteLine("SonOne.fun2");
        }
    }
    internal class SonTwo : BaseClass, Itest 
    {
        //派生类无法重写基类方法fun1,new表示重新实现Itest的fun1
        new public void fun1()
        {
            Console.WriteLine("SonOne.fun1");
        }
        //派生类可以重写基类方法fun2
        public override void fun2()
        {
            Console.WriteLine("SonOne.fun2");
        }
    }

结果:

时间: 2024-08-08 09:40:43

OOP三类继承的区别的相关文章

【C#】OOP之继承那点事

前言: 继承这点事,说多不多,说少不少,这里只描述了一些我认为的基础篇,望各位大神指教.本节参照了C#高级编程和Think in java对继承的描述,我个人认为OOP只是思想,故看明白一个就说通的,只是语法上的区别. 权限限制关键字 类继承 类继承基本写法 类继承的好处 继承中的Virtual(虚方法) 抽象类 类继承的坏处 执行循序 不可继承的类 接口继承 1.类继承 类继承基本写法: public class SuperClass : Object{} public class SubCl

接口、接口优点、接口的属性和方法特性、接口与继承的区别、接口与抽象类的区别、匿名实现类、JDK1.8新特性、打印类名称

接口里的属性,必须是公共的/默认的&静态的&Final&初始化后的属性: 接口里所有方法都是抽象的. 接口和继承---先天有的用继承,后天学习的用接口: 接口特性-------- 1.接口不可以被实例化: 2.实现类必须实现接口中所有方法,否则实现类必须是抽象类 3.实现类可以实现多个接口,来弥补Java不能多继承: 4.接口中的变量都是静态常量:(静态的-可以通过类的名字点-直接调用:) ----------------------------------------------

day10 Python作用域 Python2.7与Python3.x的类继承的区别及其他

一.Python作用域   1.Python中无块级作用域 if 1 == 1: name = 'test' print(name) #输出会报错,因为name的作用域仅限于if下的代码块,而不属于全局   2.Python中以函数为作用域 def func(): func_name = 'func_test' print(func_name) #这里同样会报错,因为变量func_name的作用于func函数中   3.Python作用域链,层层嵌套,使用时从内向外找   4.Python的作用

【C/C++学院】0822-类型转换函数与构造转换函数/类的继承/类的继承以及区别/继承静态成员与静态函数//继承实现代码重用/单继承QT案例/多继承简介以及实战/Gpu编程

类型转换函数与构造转换函数 #include<iostream> class fushu { public: explicit fushu(int num)//避免隐式转换,引发歧义 { x = num; y = num; } void print() { std::cout << x << "+" << y << "i" << std::endl; } operator int(); //不支

Lua下通过元表模拟OOP编程,继承多态

Lua本身是没有以明确的定义来支持OOP编程的,但是我们却可以通过Lua内核提供的一些特性来间接实现简单的面向对象的编程. 通过Lua中的 table结构  metatable 以及函数可以配合实现OOP,以及继承.这些说白了都是一种伪实现,不建议在Lua下使用多重继承 . 在LUA中你想要 强制实现OOP 你必须需要懂一下几个关键词!! 什么是语法糖? 语法糖即糖衣语法,C/C++升级过程中的面向对象 整体就是一种语法糖 ,是由英国计算机科学家彼得·约翰·兰达(Peter J. Landin)

装饰和继承的区别

子类用的技术都是一样的,那么有必要给他单独定一个子类吗? 这就是装饰模式生成的原因. class MyBufferReader{ MyBufferedReader(被提高效率的类1 class){} MyBufferedReader(被提高效率的类2 class){} MyBufferedReader(被提高效率的类3 class){} } -------------------------------- 优化后的代码A: class MyBufferReader extends 父类{ pri

重写,重载,多态,继承的区别。

重写,重载,多态,继承的区别: 继承是子类继承父类的方法: 重写(override)是子类重写父类允许访问的方法.返回值和参数类型必须相同. 重载(overload)就是允许多个同名但是形参个数或者类型不同的函数方法存在于同一个类里.当类统一调用方式时由形参来决定调用具体的方法. 下面是转载的一篇文章: 继承是子类获得父类的成员,重写是继承后重新实现父类的方法.重载是在一个类里一系列参数不同名字相同的方法.多态则是为了避免在父类里大量重载引起代码臃肿且难于维护. 网上看到一个有趣的说法是:继承是

装饰设计模式,以及它与继承的区别

对一组对象进行功能的增强,就可以使用到这个模式. 装饰设计模式与继承的区别? 都可以对对象的功能进行扩展,但是如果是继承,那么就需要一个继承体系,如果该对象要提高效率,就会出现为了提高效率而进行的继承,这会导致整个体系越来越臃肿,不够灵活. 装饰设计模式比继承更加灵活,不需要产生继承关系. 装饰类与被装饰类要同属于一个接口或父类. 原文地址:https://www.cnblogs.com/olddriver123/p/8274956.html

OC中protocol、category和继承的区别

利用继承,多态是一个很好的保持"对扩展开放.对更改封闭"(OCP)的办法,也是最常见的一种方法.Objective C还支持另外两种语法来支持OCP:Protocol和Category.Protocol只能定义一套接口,而不能提供实现,变相的也是一种Abstract class的实现方式(oc 语法上本身不支持抽象基类).Category可以为类提供额外的接口和实现.那么到底三者(继承, Protocol,Category)在使用上到底有什么本质的区别呢?在我看来,protocol的作