6

考虑以下代码。是否保证Derived<int>::foo()会被实例化?foo()是虚拟的,由基类的非虚拟函数调用。

#include <iostream>

class Base
{
public:
    void bar() { foo(); }
private:
    virtual void foo() = 0;
};

template <typename T> class Derived: public Base
{
public:
    Derived(T t_) : t(t_) {}
private:
    void foo() override { std::cout << t; }
    T t;
};

Derived<int> make_obj()
{
    return Derived<int>(7);
}
4

2 回答 2

7

标准部分 14.7.1/11 说

如果虚拟成员函数不会被实例化,则未指定实现是否隐式实例化类模板的虚拟成员函数。

但是,对于典型的 vtable 实现,实例化类的任何构造函数都需要一个 vtable 才能使该类存在,该 vtable 必须包含指向特化的虚函数定义的指针。所以在实践中,虚函数可能会被实例化。

于 2016-12-15T22:26:14.043 回答
0

虚拟表将始终为类层次结构实例化,但是,在您的情况下,它将取决于编译器是否 foo 在类创建时实际初始化,因为类本身是在堆栈上初始化的并且从未以多态方式使用。在您的情况下,虚拟表将毫无意义。

于 2016-12-15T22:48:14.847 回答