虚函数享有面向对象的“多态”性,考虑下面的例子:
class Base{
public:
virtual void VirtualFunc(){ cout << "Base::VirtualFunc" << endl; }
void Func(){ cout << "Base::Func" << endl; }
};
class Derived : public Base{
virtual void VirtualFunc(){ cout << "Derived::VirtualFunc" << endl; }
void Func(){ cout << "Derived::Func" << endl; }
};
int main()
{
Base b;
Derived d;
Base* pb = &b;
pb->VirtualFunc();
pb->Func();
pb = &d;
pb->VirtualFunc();
pb->Func();
return 0;
}
pb为基类类型的指针,调用虚函数时,调用的是相应的派生类对象的虚函数。而调用非虚函数时,就只能调用基类对象的函数。以上代码输出为:
Base::VirtualFunc
Base::Func
Derived::VirtualFunc
Base::Func
从语义上说,虚函数属于类的“个性”;非虚函数属于类的“共性”。
既然是“个性”,就表示基类和派生类的行为是不同的,因此派生类需要重写基类的虚函数。
对于“共性”,说明派生类的行为和基类是一样的,因此该行为可以放到基类里,派生类和基类共同使用。
需要注意的是,重写非虚函数在语义上是行不通的,既然要重写,说明派生的行为和基类的不同,那就表明是“个性”而非“共性”。如果确实要重写非虚函数,建议将其改为虚函数,以增强语义。
本文通过具体示例解释了虚函数如何实现多态性,并对比了虚函数与非虚函数的区别。虚函数允许派生类重写基类的行为,而非虚函数则保持一致性。
3099





