【问题标题】:No template argument needed for initialization of base class which is a template instance?作为模板实例的基类的初始化不需要模板参数?
【发布时间】:2021-01-03 12:33:10
【问题描述】:

我有一个派生自特定模板实例的非模板类。像往常一样,必须在派生类的构造函数中初始化基类。我发现在调用构造函数时可以省略特定的模板参数:主要编译器(VC、g++、clang)接受它。这看起来很奇怪,因为类模板本身不是类名:

$ cat template-base.cpp && g++ --pedantic -o template-base template-base.cpp  && ./template-base
template <int I>
struct T
{
        T(int) {}
};

struct DT: public T<1>
{
        // Note: T<1>(42) is possible but not necessary.
        // T<2>(42) is an error ("T<2> is not a base class", which is correct).
        DT(): T(42) {}
};

int main()
{
        DT dt;
}

(Johannes Schaub 回答了this similar question,其中派生类本身也是一个模板。在这种情况下,模板参数是强制性的,尽管它在那里同样可以很好地扣除。)

为什么我可以在这里使用类名之类的模板名? T 不是类!

【问题讨论】:

    标签: c++ templates initialization base-class


    【解决方案1】:

    这与injected class name 有关。当类模板用作基类时,该语言允许您使用模板的名称,就好像您指定了参数一样,因为它知道这些参数是什么。正在做

    DT(): T(42) {}
    

    扩展为

    DT(): T<1>(42) {}
    

    由编译器为您提供。


    可以在[temp.local]中找到允许这样做的标准语言

    【讨论】:

    • “当类模板用作基类时” 听起来有点不确定。注入的类名对于基类没有特殊情况,它是在派生类中找不到T之后在基类中通过名称查找找到的。这适用于基类是依赖类型或派生类中有成员 T 的情况。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2021-04-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多