看个简单的例子:
#include <iostream>
#include <string>
using namespace std;
class Test
{
public:
virtual void f(int i=10)
{
cout<<"这是基类"<<endl;
cout<<i<<endl;
}
};
class Plus:public Test
{
public:
void f(int j=20)
{
cout<<"这是派生类"<<endl;
cout<<j<<endl;
}
};
int main()
{
Test *p;
Test test;
p=&test;
p->f();
Plus plus;
p=+
p->f();
}
在上面的例子中,Plus类继承于Test类,我们定义了一个Test类型的指针,然而它也可以指向Plus类的对象(反过来不可以),这就是动态绑定技术,虚函数在派生类中进行重写,虽然指针是Test类型的,但具体调用哪个类中的函数决定于运行时所传递的对象,我们可以看出:父类的指针可以指向子类的对象,子类的指针却不可以指向父类的对象。
另外虚函数在子类和父类中都定义了各自的默认实参,而不管指针指向哪个对象调用函数时都输出的是父类的默认实参,这就告诉我们在定义虚函数时要谨慎使用默认实参,往往会得出错误的结果。