c++Analyse-多态的底层实现原理

多态的底层实现原理

1.使用虚函数之前

在这里插入图片描述
在这里插入图片描述

2.使用虚函数之后

Cat没有实现重写

Cat没有实现重写的时候Cat中存储的是Animal中的sperak();
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

Cat实现重写

Cat实现重写的时候Cat中存储的是Cat中的sperak();
Animal& animal=cat;
animal.speak();
animal指向的是cat的对象,将从cat的虚函数表中找到Cat::speak的地址所以打印的时候出来的是猫在说话
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

#include <iostream>
#include <string>
using namespace std;

/*
多态底层分析:
vfprt-虚函数(表)指针 v-virtual f-function ptr-pointer
*/

class Animal
{
public:
	//Speak函数就是虚函数
	//函数前面加上virtual关键字,变成虚函数,那么编译器在编译的时候就不能确定函数调用了。
 virtual void speak()
	{
		cout << "动物在说话" << endl;
	}
};

class Cat :public Animal
{
public:
	virtual void speak()
	{
		cout << "小猫在说话" << endl;
	}
};

class Dog :public Animal
{
public:

	virtual void speak()
	{
		cout << "小狗在说话" << endl;
	}

};
//我们希望传入什么对象,那么就调用什么对象的函数
//如果函数地址在编译阶段就能确定,那么静态联编,也就是地址早绑定
//如果函数地址在运行阶段才能确定,就是动态联编,也就是地址晚绑定

void DoSpeak(Animal& animal)
{
	animal.speak();
}
//
//多态满足条件: 
//1、有继承关系
//2、子类重写父类中的虚函数
//多态使用:
//父类指针或引用指向子类对象

void test01()
{
	Cat cat;
	DoSpeak(cat);   //Animal &animal=cat;  父类引用指向子类对象

	Dog dog;
	DoSpeak(dog);  //Animal &animal=dog;  父类引用指向子类对象
}


void test02()
{
	cout << "animal的大小:" << sizeof(Animal) << endl;
}

int main() {

	test01();
	test02();

	system("pause");

	return 0;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值