动态绑定技术

看个简单的例子:

#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=&plus;
	p->f();
}

在上面的例子中,Plus类继承于Test类,我们定义了一个Test类型的指针,然而它也可以指向Plus类的对象(反过来不可以),这就是动态绑定技术,虚函数在派生类中进行重写,虽然指针是Test类型的,但具体调用哪个类中的函数决定于运行时所传递的对象,我们可以看出:父类的指针可以指向子类的对象,子类的指针却不可以指向父类的对象。

另外虚函数在子类和父类中都定义了各自的默认实参,而不管指针指向哪个对象调用函数时都输出的是父类的默认实参,这就告诉我们在定义虚函数时要谨慎使用默认实参,往往会得出错误的结果。


你可能感兴趣的:(动态绑定技术)