1:
地址早绑定 在编译阶段确定函数地址
如果想执行让猫说话,那么这个函数地址就不能提前绑定,需要在运行阶段进行绑定,地址晚绑定
动态多态满足条件
1:有继承关系
2:子类重写父类的虚函数
重写:返回值类型相同 函数名 参数列表 完全相同
动态多态的使用:
父类的指针或者引用 指向子类对象
#include<iostream>
using namespace std;
class Animal
{
public:
//虚函数
virtual void speak()
{
cout << "动物在说话 " << endl;
}
};
//猫类
class Cat :public Animal
{
public :
void speak()
{
cout << "猫在说话" << endl;
}
};
class Dog :public Animal
{
public :
void speak()
{
cout << "狗在说话" << endl;
}
};
//执行说话的函数
/*
地址早绑定 在编译阶段确定函数地址
如果想执行让猫说话,那么这个函数地址就不能提前绑定,需要在运行阶段进行绑定,地址晚绑定
动态多态满足条件
1:有继承关系
2:子类重写父类的虚函数
重写:返回值类型相同 函数名 参数列表 完全相同
动态多态的使用:
父类的指针或者引用 指向子类对象
*/
void doSpeak(Animal& animal)//Animal &animal=Cat---Animal& animal 地址早绑定
{
animal.speak();
}
void test01()
{
Cat cat;
Dog dog;
Animal animal;
doSpeak(cat);
doSpeak(dog);
doSpeak(animal);
}
int main()
{
test01();
return 0;
}
2:分别利用普通写法和多态技术实现计算器
(1)如果想要扩展新的功能,需要修改源代码
(2)在真实的开发中 提倡 开闭原则: 对扩展进行开发 对修改进行关闭
(3)多态的好处:
1:组织结构清晰
2:可读性强
3:对于前期和后期扩展及维护性高
(4)多态使用条件
父类指针或则引用指向子类对象
#include<iostream>
#include<string>
using namespace std;
//分别利用普通写法和多态技术实现计算器
//普通写法
class Calculator
{
public:
int getResult(string oper)
{
if (oper == "+")
{
return m_Num1 + m_Num2;
}
if (oper == "-")
{
return m_Num1 - m_Num2;
}
if (oper == "*")
{
return m_Num1 * m_Num2;
}
}
/*
如果想要扩展新的功能,需要修改源代码
在真实的开发中 提倡 开闭原则: 对扩展进行开发 对修改进行关闭
*/
int m_Num1;//操作数1
int m_Num2;
};
void test01()
{
Calculator c;
c.m_Num1 = 10;
c.m_Num2 = 10;
cout << c.m_Num1 << "+" << c.m_Num2 << "=" << c.getResult("+") << endl;
cout << c.m_Num1 << "-" << c.m_Num2 << "=" << c.getResult("-") << endl;
cout << c.m_Num1 << "*" << c.m_Num2 << "=" << c.getResult("*") << endl;
}
//利用多态实现计算器
/*
多态的好处:
1:组织结构清晰
2:可读性强
3:对于前期和后期扩展及维护性高
*/
//实现计算器抽象类
class AbstractCalculator
{
public :
virtual int getResult()
{
return 0;
}
int m_Num1 =10;
int m_Num2=10;
};
//加法计算器
class AddCalculator :public AbstractCalculator
{
public:
int getResult()
{
return m_Num1 + m_Num2;
}
};
class SubCalculator :public AbstractCalculator
{
public:
int getResult()
{
return m_Num1 - m_Num2;
}
};
class MulCalculator :public AbstractCalculator
{
public:
int getResult()
{
return m_Num1 * m_Num2;
}
};
void test02()
{
//多态使用条件
//父类指针或则引用指向子类对象
AbstractCalculator *abc = new AddCalculator;
//创建加法计算器
abc->m_Num1 = 10;
abc->m_Num2 = 10;
cout << abc->m_Num1 << "+" << abc->m_Num2 << "=" << abc->getResult() << endl;
delete abc;//用完记得销毁
//创建乘法计算器
abc = new MulCalculator;
abc->m_Num1 = 10;
abc->m_Num2 = 10;
cout << abc->m_Num1 << "*" << abc->m_Num2 << "=" << abc->getResult() << endl;
delete abc;
//用完记得销毁
abc = new SubCalculator;
abc->m_Num1 = 10;
abc->m_Num2 = 10;
cout << abc->m_Num1 << "-" << abc->m_Num2 << "=" << abc->getResult() << endl;
delete abc;
//用完记得销毁
}
int main()
{
//test01();
test02();
return 0;
}``
3:
(1):纯虚函数:
只要有一个纯虚函数,这个类称为抽象类
子类必须重写父类中的纯虚函数,否则无法实例化对象
抽象类的特点;
1:无法示例化
2:抽象类的子类 必须要重写父类中 的纯虚函数,否则也属于抽象类
```cpp
#include<iostream>
using namespace std;
class Base
{
public:
virtual void func() = 0;
/*
纯虚函数:
只要有一个纯虚函数,这个类称为抽象类
抽象类的特点;
1:无法示例化
2:抽象类的子类 必须要重写父类中 的纯虚函数,否则也属于抽象类
*/
};
class Son :public Base
{
public:
virtual void func() //重写父类中的纯虚函数
{
cout << "func函数调用" << endl;
};
};
void test01()
{
// Base b; 抽象类是无法实例化对象
//new Base ; 抽象类是无法实例化对象
//Son s;//子类必须重写父类中的纯虚函数,否则无法实例化对象
Base* base = new Son;
base->func();
delete base;
}
int main()
{
test01();
return 0;
}