内联函数不能为虚函数,原因在于虚表机制需要一个真正的函数地址,而内联函数展开以后,就不是一个函数,而是一段简单的代码(多数C++对象模型使用虚表实现多态,对此标准提供支持),可能有些内联函数会无法内联展开,而编译成为函数。
class Foo
{
public:
virtual void vFunc() const;
private:
};
class Child: public Foo
{
public:
virtual void vFunc() const;
};
inline
void Foo::vFunc() const
{cout<<"class Foo"<<endl;}
inline
void Child::vFunc() const
{
cout<<"class Child"<<endl;
}
int main()
{
Foo* pCh = new Child;
pCh->vFunc();
return 0;
}
输出为Child!即使虚函数是内联函数仍然正确的动态绑定!
原因是:即使虚函数被声明为内联函数,编译器遇到这种情况根本不会把这样的函数内联展开,而是当做普通函数来处理。
构造函数肯定不能作为虚函数。虚函数是为了在继承的类里面用同样的函数名来实现RTTI的。构造函数不需要也不可能让你RTTI!(子类名不可能与父类名相同)
原文链接: https://www.cnblogs.com/kex1n/archive/2010/01/15/1648380.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/6825
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!