但是在實際工作中,很可能會碰到對象所屬類不清的情況,下面我們來看一下衍生類別成員作為函數參數傳遞的例子,代碼如下:
//常式2
#include <iostream
>
using
namespace
std;
class
Vehicle
{
public
:
Vehicle(float
speed,int
total)
{
Vehicle::speed=speed;
Vehicle::total=total;
}
void
ShowMember()
{
cout
<<speed<<"|"<<total<<endl;
}
protected
:
float
speed;
int
total;
};
class
Car:public
Vehicle
{
public
:
Car(int
aird,float
speed,int
total):Vehicle(speed,total)
{
Car::aird=aird;
}
void
ShowMember()
{
cout
<<speed<<"|"<<total<<"|"<<aird<<endl;
}
protected
:
int
aird;
};
void
test(Vehicle &temp)
{
temp.ShowMember();
}
void
main
()
{
Vehicle a(120,4);
Car b(180,110,4);
test(a);
test(b);
cin
.get();
}
例子中,對象a與b分辨是基類和衍生類別的對象,而函數test的形參卻只是Vehicle類的引用,按照類繼承的特點,系
統把Car類對象看做是一個Vehicle類對象,因為Car類的覆蓋範圍包含Vehicle類,所以test函數的定義並沒有錯誤,我們想利用test
函數達到的目的是,傳遞不同類對象的引用,分別調用不同類的,重載了的,ShowMember成員函數,但是程式的運行結果卻出乎人們的意料,系統分不清楚傳遞過來的
基類對象還是衍生類別對象
,無論是基類對象還是衍生類別對象調用的都是基類的ShowMember成員函數。