虚函数:
直接看代码
class Base//基类
{
int a;
public:
Base(){a=1;}
void disp(){cout<<a;};
};
class Drived: public Base//Base的派生类
{
int b;
public:
Drived(){ b=2;}
void disp(){cout<<b;}
};
int main( int argc, char* argv[])
{
Base* p;
Base dt1;
Drived dt2;
p=&dt1;//p指向基类
p->disp();
cout<<endl;
p=&dt2;//p仍指向基类
p->disp();
}
运行结果
解释
1.最后两行p=&dt2; p->disp();
虽然表面上看来是调用dt2.disp( )函数,显示当前对象中b,而实际上是调用dt2对象中所继承的基类中的disp( )函数,也就是只显示a,这是因为p被定义为指向基类cBase对象的指针。
因此,利用指针p来调用的disp( )函数,一定是基类中的disp( )函数,这是由于在编译时就已经决定了p与Base类相结合的关系,这种结合被称为静态结合(又被称为静态联编)。静态结合方式是在编译阶段就确定好的,这种结合方式在程序运行过程中是不能改变的。
2.若想调用dt2.dsip(),可以采用两种方法,
1)直接使用dt2.disp();
2)将基类中的同名函数改为虚函数,具体操作为:在返回类型名前加上virtual;
virtual void disp(){cout<<a;};
运行结果如图: