/*
* 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函数。