【C++】多态(多态的构成条件,虚函数重写,override,final,覆盖隐藏对比)

文章目录


前言

多态的概念:通俗来说,就是多种形态,具体点就是去完成某个行为,当不同的对象去完成时会产生出不同的状态。
举个栗子:多态是在不同继承关系的类对象,去调用同一函数,产生了不同的行为。比如Student继承了Person。Person对象买票全价,Student对象买票半价。

一、多态的定义及实现

1.多态的构成条件:

  1. 必须通过基类的指针或者引用调用虚函数
  2. 被调用的函数必须是虚函数 ,且派生类必须对基类的虚函数进行重写

二、虚函数

虚函数:即被virtual修饰的类成员函数称为虚函数。

1.虚函数的重写

虚函数的重写(覆盖):派生类中有一个跟基类完全相同的虚函数(即派生类虚函数与基类虚函数的返回值类型、函数名字、参数列表完全相同),称子类的虚函数重写了基类的虚函数。

2.虚函数重写的例外(协变)

协变(基类与派生类虚函数返回值类型不同)派生类重写基类虚函数时,与基类虚函数返回值类型不同。即基类虚函数返回基类对象的指针或者引用,派生类虚函数返回派生类对象的指针或者引用时,称为协变。(基类虚函数不能返回派生类的指针或者引用,派生类虚函数也不能返回基类的指针或者引用)

cpp 复制代码
class A
{};

class B : public A
{};

class Person {
public:
	virtual	A* BuyTicket() const { 
		cout << "买票-全价" << endl;
		return 0;
	}
};

class Student : public Person {
public:
	virtual B* BuyTicket() const { 
		cout << "买票-半价" << endl;
		return 0;
	}
};

3.析构函数的虚函数(基类与派生类析构函数名字不同)

问:析构函数加virtual,是不是虚函数重写?

答:是, 因为类析构函数都被处理成destructor这个统一的名字
问:为什么要这么处理呢?

答:因为要让他们构成重写

1.不加virtual的一般情况:

2.不加virtual会出现异常的情况

3.析构函数加上virtual后

加上virtual以后我们就可以根据指针指向的类型利用多态去调用对象对应的析构函数

如果只是普通的析构,他只会根据对象的类型去调用类型对应的析构函数

三、C++11 override 和 final

1.override

检查派生类虚函数是否重写了基类某个虚函数,如果没有重写编译报错。

2.final

1.修饰虚函数,表示该虚函数不能再被重写

2.设计不想被继承的类

四、 重载、覆盖(重写)、隐藏(重定义)的对比

小试牛刀

相关推荐
东坡白菜2 小时前
破局全栈:一个前端开发的Java入门实战记录(1)
java·全栈
clint4562 小时前
C++进阶(1)——前景提要
c++
唐青枫2 小时前
Java Tomcat 实战指南:从 Servlet 容器到 Spring Boot 部署
java
wsaaaqqq2 小时前
roudan:自由选择实体、灵活操作数据、快速写入数据库的 Java 框架
java
夜悊6 小时前
C++代码示例:进制数简单生成工具
c++
plainGeekDev6 小时前
null 判断 → Kotlin 可空类型
android·java·kotlin
糖拌西瓜皮6 小时前
Java开发者视角:深入理解Node.js异步编程模型
java·后端·node.js
plainGeekDev6 小时前
getter/setter → Kotlin 属性
android·java·kotlin
一线大码6 小时前
Smart-Doc 的简单使用
java·后端·restful
郝学胜_神的一滴7 小时前
CMake 021: IF 条件判据详诠
c++·cmake