多态的底层实现原理
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;
}