令人意外的是,竟然可以为pure virtual 函数提供定义。但调用它的唯一途径是“调用时明确指出其class 名称”,如下代码:
#include <iostream>
using namespace std;
class Test
{
private:
int a;
int b;
public:
//注意:这是纯虚函数
virtual int getvalue() = 0
{
//缺省实现
return a + b;
}
Test(int x,int y)
{
a = x;
b = y;
}
};
class Test2 :public Test
{
public:
Test2(int x, int y) :Test(x, y)
{
}
virtual int getvalue() override
{
cout << "子类将使用父类的缺省实现\n";
//使用缺省的实现
return Test::getvalue();
}
};
void main()
{
Test *pT = new Test2(10,20);
cout << pT->getvalue() << endl;
system("pause");
}
结果:
利用这一特性可以实现某些缺省实现。不需要另外再开一个函数。
这个设计纯虚函数被分割成了两部分:声明部分表现为接口(那是derived classes必须使用的),其定义部分则表现出缺省行为(那是derived classes 可能会使用的,但只有在他们明确提出申请时才会。)