2013 第十四周 修改程序

/* 
* Copyright (c) 2013, 烟台大学计算机学院                     
* All rights reserved.                     
* 文件名称:test.cpp                     
* 作者:樊露露                    
* 完成日期:2013 年 5 月 31 日                     
* 版本号:v1.0                   
*                     
* 输入描述:无                     
* 问题描述:                  
* 程序输出:
 * 问题分析:                    
* 算法设计:略                     
*/         


 

 

先看一段程序:

#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;
   vp->run();
   vp=&airplane;
   vp->run();
   return 0;
}


这段程序输出的结果为:

可以看见(B)用指向基类的指针访问成员函数下面输出的都是“run a vehicle。”,而我们的目的却不是这样的。

 

我们可以修改基类而让后面的输出发生改变:

class Vehicle //交通工具
{
public:
    virtual void run() const
    {
        cout<<"run a vehicle"<<endl;
    }
};

在基类中成员函数run前面加上virtual,就可以改变输出结果,我们来看看结果:

 

从图中我们可以看出在(B)中输出结果发生了改变。

是因为 在基类中的成员函数 run 前面 加了一个 virtual,使run函数变成了虚函数,在声明Car和Airplane这两个派生类时 虚函数run会被重载,这样,基类中的虚函数run会被派生类中的同名函数取代,所以,在调用run函数时就调用的派生类中的run函数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值