c++多态与虚函数

/* C++ 多态 与 虚函数 */

/* 多态(polymorphism)”指的是同一名字的事物可以完成不同的功能 */
/* 分为编译时的多态和运行时的多态:
    编译时多态:函数的重载(包括运算符的重载)、对重载函数的调用,在编译时就能根据实参确定应该调用哪个函数
    运行时多态:和继承、虚函数等概念有关 */
/* 只有派生类的虚函数覆盖基类的虚函数(函数原型相同)才能构成多态(通过基类指针访问派生类函数)*/
#include <iostream>
using namespace std;
//基类People
class People
{
public:
    People(char *name, int age);
    //void display();
    virtual void display();

protected:
    char *m_name;
    int m_age;
};
People::People(char *name, int age) : m_name(name), m_age(age) {}
void People::display()
{
    cout << m_name << "今年" << m_age << "岁了,是个无业游民。" << endl;
}
//派生类Teacher
class Teacher : public People
{
public:
    Teacher(char *name, int age, int salary);
    void display(); //基类中的函数声明为虚函数,所有派生类中具有遮蔽关系的同名函数都将自动成为虚函数

private:
    int m_salary;
};
Teacher::Teacher(char *name, int age, int salary) : People(name, age), m_salary(salary) {}
void Teacher::display()
{
    cout << m_name << "今年" << m_age << "岁了,是一名教师,每月有" << m_salary << "元的收入。" << endl;
}
int main()
{
    //1、试图通过基类对象指针访问派生类成员函数(向下转型?)
    People *p = new People("安琪拉", 23);
    p->display(); //p 指向派生类 People 的对象时,使用了 People 的成员变量和成员函数
    p = new Teacher("赵云", 45, 8200);
    p->display(); //p 指向派生类 Teacher 的对象时,虽然使用了 Teacher 的成员变量,但是却没有使用它的成员函数 这似乎很不科学!
                  /* 通过基类指针只能访问派生类的成员变量,但是不能访问派生类的成员函数 */

    //2、为了消除这种尴尬,让基类指针能够访问派生类的成员函数,C++ 增加了虚函数(Virtual Function)
    /*在函数声明display()前面增加 virtual 关键字 就可以通过基类对象指针访问派生类成员了。
      也就是说基类指针可以按照基类的方式来做事,也可以按照派生类的方式来做事(取决于基类对象指针指向谁),它有多种形态. */

    //3、借助引用也可以实现多态(不用加 virtual 关键字)
    People p1("安琪拉", 23);
    Teacher t1("赵云", 45, 8200);
    People &r = p1; //引用只能指代固定的对象
    People &r1 = t1;
    p1.display();
    t1.display();

    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值