继承中的隐藏:(不要使用隐藏,语法没有错误但是开发项目时会被视为错误)

在继承类中完全保留基类中的函数名

//基类,交通工具
class Vehicle
{
public void Run()
{
Console.WriteLine("Vehicle Run");
}
}
//派生类,汽车
class Car : Vehicle
{
public void Run()
{
Console.WriteLine("Car RunRun");
}
}

隐藏之后,Car中的Run()有两个版本,一个是继承来的Run() 被隐藏,另一个是Car中新写的Run()。

两个版本共存,

如果引用类型是父类,实例类型是子类,调用隐藏方法,

如果引用类型是子类,实例类型也是子类,调用新写的方法,

继承中的重写:

基类中Run()函数前加”virtual “,virtual 在这里翻译为形式上的,名存实亡的,其实就是为以后override重写做铺垫

派生类中的Run()函数前加”override“。

//基类,交通工具
class Vehicle
{
public void virtual Run()
{
Console.WriteLine("Vehicle Run");
}
}
//派生类,汽车
class Car : Vehicle
{
public void override Run()
{
Console.WriteLine("Car Run");
}
}

重写之后,Car中的Run()方法只有一个版本,原来继承的Run()已经被新写的Run()覆盖。

在子类中仅存在一个版本,所以无论引用类型是父类还是子类,只要实例类型是子类,则调用的就是新写的方法。

举例说明:

hide:

Car类中更新Run()的新版本和旧版本共存,

但是我们用父类类型Vehicle作为引用的类型,

子类类型Car类做实例类型

就调用旧的版本(I‘m running.)

    class Program
{
static void Main(string[] args)
{
Vehicle car = new Car();//C#支持父类类型变量引用一个子类类型实例,is a. 一辆car是一个Vehicle
car.Run();
}
} class Vehicle
{
public void Run()
{
Console.WriteLine("I'm running");
}
} class Car : Vehicle
{
public void Run()
{
Console.WriteLine("Car is running");
}
}

结果是:

I‘m running.

直接Car car = new Car();才返回Car类中的新版本!

override:

重写一次Run()方法,即在Car类中更新Run()的新版本(Car is running.),旧的版本(I‘m running.)被重写(覆盖)

我们用父类类型Vehicle作为引用的类型,Car类做实例类型,

就调用新的版本(Car is running.)

    class Program
{
static void Main(string[] args)
{
Vehicle car = new Car();
car.Run();
}
} class Vehicle
{
public virtual void Run()
{
Console.WriteLine("I'm running");
}
} class Car : Vehicle
{
public override void Run()
{
Console.WriteLine("Car is running");
}
}

结果是:

Car is running.

override:

添加RaceCar类再重写一次Run()方法,即在RaceCar类中更新Run()的新版本(RaceCar is running.)

我们用父类类型Car作为引用的类型,RaceCar类做实例类型,(我们用父类类型Vehicle作为引用的类型,RaceCar类做实例类型,结果也相同)

就调用新的版本(RaceCar is running.)

    class Program
{
static void Main(string[] args)
{
Car car = new RaceCar();//C#支持父类类型变量引用一个子类类型实例,is a. 一辆car是一个Vehicle
car.Run();
}
} class Vehicle
{
public virtual void Run()
{
Console.WriteLine("I'm running");
}
} class Car : Vehicle
{
public override void Run()
{
Console.WriteLine("Car is running");
}
} class RaceCar : Car
{
public override void Run()
{
Console.WriteLine("RaceCar is running");
}
}

结果是:

RaceCar is running.

以上代码回答了一个问题——什么是多态?

多态就是当我们用一个父类的变量,引用一个子类的实例,调用被重写的成员的时候,总是会调用到最新的版本(与实例类型相关联的版本)

为什么会出现多态的现象?

因为C#语言中,变量的类型和实例对象的类型,是可以不同的。比如:

Car car = new RaceCar();

变量car的类型是Car,实例类型是RaceCar。这样就有代差,可以用基类类型的变量引用子类类型实例,反之不可

继承中的隐藏(hide)重写(Override)和多态(Polymorphism)的更多相关文章

  1. C++因继承引发的隐藏与重写

    在区分隐藏和重写之前,先来理一理关于继承的东西... [继承] 继承是面向对象复用的重要手段.通过继承定义一个类,继承是类型之间的关系建模,共享公有的东西,实现各自本质不同的东西.简单的说,继承就是指 ...

  2. C++继承引入的隐藏与重写

    在区分隐藏和重写之前,先来理一理关于继承的东西... [继承] 继承是面向对象复用的重要手段,是类型之间的关系建模.通过继承一个类,共享公有的东西,实现各自本质不同的东西.简单的说,继承就是指一个对象 ...

  3. [18/11/29] 继承(extends)和方法的重写(override,不是重载)

    一.何为继承?(对原有类的扩充) 继承让我们更加容易实现类的扩展. 比如,我们定义了人类,再定义Boy类就只需要扩展人类即可.实现了代码的重用,不用再重新发明轮子(don’t  reinvent  w ...

  4. 【C++】继承中的隐藏与覆盖

    没有访问控制符时默认为私有继承. 当基类中的某个函数有若干个重载版本,继承类中也实现了该函数的某个重载版本时,参数完全相同的基类版本被覆盖,基类的其他版本被隐藏. 1.若要在继承类中使用基类的被覆盖方 ...

  5. js---17继承中方法属性的重写

    function F(){}; var f = new F(); f.name = "cf"; f.hasOwnProperty("name");//true ...

  6. 关于在C#中对类中的隐藏基类方法和重写方法的理解

    最近在学习C#,在C#中的类看到重写和隐藏基类的方法这些概念.才开始感觉自己不是很理解这些概念.也区分不开这些概念.通过自己的查找资料和练习后.慢慢的理解了类中的隐藏和重写这个概念.在C#中只有在基类 ...

  7. 重载(overload),覆盖/重写(override),隐藏(hide)

    写正题之前,先给出几个关键字的中英文对照,重载(overload),覆盖/重写(override),隐藏(hide).在早期的C++书籍中,常常把重载(overload)和覆盖(override)搞错 ...

  8. C#中隐藏(new)、方法重写(override)、重载(overload)的区别

    转自:http://www.cnblogs.com/glife/archive/2009/12/28/1633947.html 重载.重写和隐藏的定义: 重载:public string ToStri ...

  9. c++中的重载(Overload)、覆盖(重写,Override) 、隐藏与using声明

    这些概念有时记住了,但可能没多久就忘了,还是记下来吧.网上找的一篇不错:这里  1 重载与覆盖 成员函数被重载的特征: (1)相同的范围(在同一个类中,不包括继承来的): (2)函数名字相同: (3) ...

随机推荐

  1. 一、基础项目构建,引入web模块,完成一个简单的RESTful API

    一.Spring Boot的主要优点: 为所有Spring开发者更快的入门 开箱即用,提供各种默认配置来简化项目配置 内嵌式容器简化Web项目 没有冗余代码生成和XML配置的要求 二.使用maven构 ...

  2. 欧拉路径 && 欧拉回路

  3. IntelliJ IDEA 添加本地xsd文件

    地址: http://code.alibabatech.com/schema/dubbo/dubbo.xsd

  4. 历史上最详细的SpringCloud搭建微服务的过程。(包括注册中心,服务提供者和服务消费者)

    首先搭建注册中心,创建一个springboot的maven工程. 工程创建完成之后,先在资源文件中的application.properties中写配置文件. server.port= spring. ...

  5. 创建TCP服务器和TCP客户端

    import sockethost='127.0.0.1'port=8080web=socket.socket()web.bind((host,port))web.listen(5)# 设置最多连接数 ...

  6. stm32 hal库串口通信资料汇集

    串口的发送接收函数:HAL_UART_Transmit();串口轮询模式发送,使用超时管理机制.HAL_UART_Receive();串口轮询模式发送,使用超时管理机制.HAL_UART_Transm ...

  7. Delphi GDI+ 安装方法

    [转]Delphi GDI+ 安装方法转自:万一博客(http://www.cnblogs.com/del/)GDI+ 是 Windows 的一个函数库, 来自 Windows\System32\GD ...

  8. jmeter之-图形监控

    一.安装 https://jmeter-plugins.org/downloads/old/ 下载JMeterPlugins-Standard-1.4.0(监听器-图形界面)和ServerAgent- ...

  9. apk签名原理及实现

    发布过Android应用的朋友们应该都知道,Android APK的发布是需要签名的.签名机制在Android应用和框架中有着十分重要的作用. 例如,Android系统禁止更新安装签名不一致的APK: ...

  10. 数据结构学习笔记——顺序数组1

    线性表最简单的刚开始就是顺序存储结构,我是看着郝斌的视频一点一点来的,严蔚敏的书只有算法,没有具体实现,此笔记是具体的实现 为什么数据结构有ADT呢,就是为了满足数据结构的泛性,可以在多种数据类型使用 ...