第十三周阅读程序4:继承与指针

问题及代码:

#include <iostream>
using namespace std;
class Vehicle  //交通工具
{
public:
    void run() const
    {
        cout << "run a vehicle. "<<endl;
    }
};
class Car: public Vehicle  //汽车
{
public:
    void run() const
    {
        cout << "run a car. "<<endl;
    }
};
class Airplane: public Vehicle  //飞机
{
public:
    void run() const
    {
        cout << "run a airplane. "<<endl;
    }
};
int main()
{
    cout<<"(a) 直接用对象访问成员函数: "<<endl;
    Vehicle v;
    v.run();
    Car car;
    Airplane airplane;
    car.run();
    airplane.run();
    cout<<"(b)用指向基类的指针访问成员函数: "<<endl;
    Vehicle *vp;    //建立一个基类的指针
    vp=&car;        //对car对象取地址
    vp->run();
    vp=&airplane;   //对airplan对象取地址
    vp->run();
    return 0;
}


(1)请写出程序的执行结果,并在上机时对照理解

请回答:当基类的指针指向派生类时,用指针调用同名成员函数,执行的是基类的成员函数,还是派生类的成员函数?为什么会这样?


在继承关系中直接用对象访问不同类的同名成员函数是可以的。

但是用指向基类的指针访问的时候,基类指针是无法访问派生类中非继承的成员函数和数据成员的。所以输出的结果仍然是继承而来的基类的成员函数,输出

run a vehicle.

run a vehicle.


(2)如果将Vehicle类的定义修改为虚函数,其余不变,请写出程序的执行结果

请回答:当基类的指针指向派生类时,用指针调用同名虚成员函数,执行的是基类的成员函数,还是派生类的成员函数?为什么会这样?什么是多态性?请结合本例的运行结果说明


将基类同名函数设置为虚函数,则在派生类中的同名函数就会相当于覆盖掉了基类中的虚函数,所以指向基类的指针可以理所当然的可以指向派生类的成员函数,输出

run a car.

run a aieplane.

这正是体现了动态多态性。


(3)如果将Vehicle类的定义修改为纯虚函数,找出main()函数中将使编译出错的行删除(或改为注释),请写出程序的执行结果,并在上机时对照理解

virtual void run() const = 0; //(3) run()为纯虚函数,const意指其为常成员函数,并非纯虚函数之必要

请回答:当基类同名成员函数定义为纯虚函数后,发生了什么现象?为什么会这样?


含有纯虚函数的类,变成了虚基类,而在虚基类是不能定义对象的。


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值