#include <stdio.h>
template<typename T, typename T2, template <typename T> class TemplateClass>
class TemplateTemplateClass {
public:
TemplateTemplateClass(const TemplateClass& tempClass)
: _internalClass(tempClass) {
}
void doTest() {
_internalClass.doTest();
}
private:
TemplateClass _internalClass;
};
编译时的上述代码将在下面给出错误消息:
$ g++ TemplateTemplateClass.cpp
TemplateTemplateClass.cpp:7:33: error: invalid use of template-name 'TemplateClass' without an argument list
TemplateTemplateClass.cpp:7:48: error: ISO C++ forbids declaration of 'tempClass' with no type [-fpermissive]
TemplateTemplateClass.cpp:15:5: error: invalid use of template-name 'TemplateClass' without an argument list
TemplateTemplateClass.cpp: In constructor 'TemplateTemplateClass<T, T2, TemplateClass>::TemplateTemplateClass(const int&)':
TemplateTemplateClass.cpp:8:11: error: class 'TemplateTemplateClass<T, T2, TemplateClass>' does not have any field named '_internalClass'
TemplateTemplateClass.cpp: In member function 'void TemplateTemplateClass<T, T2, TemplateClass>::doTest()':
TemplateTemplateClass.cpp:12:9: error: '_internalClass' was not declared in this scope
如果我改变它如下,则可以成功编译。
class TemplateTemplateClass {
public:
TemplateTemplateClass(const TemplateClass<T>& tempClass)
: _internalClass(tempClass) {
}
void doTest() {
_internalClass.doTest();
}
private:
TemplateClass<T> _internalClass;
};
因此,考虑到上述错误消息,我的问题是TemplateClass<T>
,<T>
是什么意思?为什么不能删除?
答案 0 :(得分:1)
您告诉编译器TemplateClass
是一个采用单一类型参数的模板:
template<typename T, typename T2, template <typename T> class TemplateClass>
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
现在,为了使用TemplateClass
,您必须告诉编译器该参数是什么,例如T
,T2
,int
,std::string
等。
答案 1 :(得分:1)
template <typename T> class TemplateClass
表示TemplateClass
是模板类。在提供所需类型之前,模板是不完整的类。在这种情况下,您应该提供T
。