多态分为两类
静态多态:函数重载 和 运算符重载
动态多态:派生类和虚函数实现运行,我们指的多态多指动态多态
区别:
静态多态的函数地址,在编译阶段就已经确定了
动态多态的函数地址,在运行阶段才确定了
动态多态满足条件:
1.有继承关系
2.子类要重写父类中的虚函数
复习:重写:函数返回值类型,函数名,参数列表完全相同,区别重载
动态多态的使用:
父类的指针 或者 引用,执行子类对象(引用:达到改变函数外的变量)
#include<iostream>
using namespace std;
class Animal {
public:
void speak() {
cout << "动物在说话" << endl;
}
};
class Cat : public Animal{
public:
void speak() {
cout << "小猫在喵喵叫" << endl;
}
};
//地址早绑定,在编译阶段就确定了函数地址
//即使传入的是Cat类,但是在编译时候,
//已经确定了animal.speak(); => "动物在说话"
//而不是mao.speak(); =>"小猫在喵喵叫"
//所以 此时不管传入什么类,调用的都是父类的函数
void doSpeak(Animal &animal) {//Animal 父类
animal.speak();
}
void test01() {//Cat 子类
Cat mao;
doSpeak(mao);
}
int main() {
test01();
system("pause");
}
#include<iostream>
using namespace std;
class Animal {
public:
//把父类的方法加上virtual 变成虚函数,此时晚绑定
virtual void speak() {
cout << "动物在说话" << endl;
}
};
class Cat : public Animal{
public:
void speak() {
cout << "小猫在喵喵叫" << endl;
}
};
class Dog : public Animal {
public:
void speak() {
cout << "brak brak!!" << endl;
}
};
//由于.speak()是虚函数,所以animal的地址暂时不确定,
//取决于传进来的对象是什么
//传进来是狗,就是gou.speak();
//传进来是猫,就是mao.speak();
void doSpeak(Animal &animal) {//Animal 父类
animal.speak();
}
void test01() {//Cat 子类
Cat mao;
doSpeak(mao);
Dog gou;
doSpeak(gou);
}
int main() {
test01();
system("pause");
}