-1
#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;
};

所以考虑到上面的错误信息,我的问题是 in 是TemplateClass<T>什么<T>意思?为什么不能删除?

4

2 回答 2

1

您已经告诉编译器这TemplateClass是一个采用单一类型参数的模板:

template<typename T, typename T2, template <typename T> class TemplateClass>
                                  ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^

现在,为了使用TemplateClass,您必须告诉编译器该参数是什么,例如TT2intstd::string

于 2013-03-23T09:16:35.113 回答
1
template <typename T> class TemplateClass

TemplateClass是一个模板类。在您提供所需类型之前,模板是不完整的类。在这种情况下,您应该提供T.

于 2013-03-23T09:18:06.967 回答