【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.设计不想被继承的类

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

小试牛刀

相关推荐
雨中飘荡的记忆4 小时前
ElasticJob分布式调度从入门到实战
java·后端
考虑考虑13 小时前
JDK25模块导入声明
java·后端·java ee
_小马快跑_14 小时前
Java 的 8 大基本数据类型:为何是不可或缺的设计?
java
Re_zero17 小时前
线上日志被清空?这段仅10行的 IO 代码里竟然藏着3个毒瘤
java·后端
洋洋技术笔记17 小时前
Spring Boot条件注解详解
java·spring boot
程序员清风1 天前
程序员兼职必看:靠谱软件外包平台挑选指南与避坑清单!
java·后端·面试
端平入洛1 天前
delete又未完全delete
c++
皮皮林5511 天前
利用闲置 Mac 从零部署 OpenClaw 教程 !
java
华仔啊2 天前
挖到了 1 个 Java 小特性:var,用完就回不去了
java·后端
SimonKing2 天前
SpringBoot整合秘笈:让Mybatis用上Calcite,实现统一SQL查询
java·后端·程序员