Rya*_*yan 9 c++ inheritance templates class
我不敢相信gcc不会接受以下代码...请告诉我,如果从基本模板访问内部类是真的不可能或我错过了什么?
template <class T> class BaseClass
{
public:
struct MyStruct
{
T *data;
};
};
template <class T> class ChildClass : public BaseClass <T>
{
public:
void problem()
{
MyStruct ms1; //error: 'MyStruct' was not declared in this scope
::MyStruct ms2; //error: '::MyStruct' has not been declared
BaseClass<T>::MyStruct ms3; //error: expected `;' before 'ms3'
}
};
Run Code Online (Sandbox Code Playgroud)
Jam*_*lis 15
问题是它MyStruct
是一个依赖名称,因此您必须告诉编译器推迟名称查找,直到通过使用基类名称对其进行限定来实例化模板:
typename BaseClass<T>::MyStruct ms1;
Run Code Online (Sandbox Code Playgroud)
有关更多信息,我阅读了Parashift C++ FAQ条目,"当我的模板派生类使用它从模板基类继承的嵌套类型时,为什么会出错?"
BaseClass<T>::MyStruct ms3;
Run Code Online (Sandbox Code Playgroud)
应该
typename BaseClass<T>::MyStruct ms3;
Run Code Online (Sandbox Code Playgroud)
由于它MyStruct
是一个从属名称,即它取决于模板参数.
相关:我在哪里以及为什么必须在依赖名称上加上"template"和"typename"?