数据成员'vec'不能是成员模板

data member 'vec' cannot be a member template

本文关键字:成员 vec 数据成员 不能      更新时间:2023-10-16

为了声明包含模板的向量,我在标头中有以下两行:

template <class t>
std::vector <t> vec;

然而,我得到以下错误:

data member 'vec' cannot be a member template

我做错了什么?

编辑:我不知道我是否被正确理解,我正在尝试声明一个包含模板的向量,我知道这是可以做到的,因为可以有以下内容:

template <class T>
void funct(vector <T> v){
}

此函数将模板的矢量作为其参数。我希望做同样的事情,除了在头中声明向量,以便允许向量包含任何内容。

template <>语句仅在声明函数模板类模板时使用。例如,您可以在声明(和定义)一个类时使用它:

template <typename T>
class TemplateClass {
    /* definition */
};

或者一个函数:

template <typename T>
void templateFunc(T value) {
    /* definition */
}

创建类的实例时,不能使用template <>语句。相反,您可以指定这样的模板参数:

TemplateClass<int> tc;

调用模板函数时:

int i = 1;
templateFunc(i); // <-- Automatic template deduction to int.

这样的向量不能包含任何内容。

假设编译器允许您声明这样一个向量,并编写:

//...
A Aobj;
vec.push_back(Aobj);
//...

那么vec中的一个元素的大小将是sizeof(A)。但接下来你会写:

//...
B Bobj;
vec.push_back(Bobj);
//...

这里一个元素的大小是多少?

无论如何,作为一种变通方法,您可以声明vector<void*> vec,这样向量就可以包含指向任何您想要的对象的指针。

此答案适用于C++11及更早版本


没有模板化的数据成员。模板的种类只有类模板函数模板。您的另一个示例是函数模板。

试着想想别人会如何实例化你的类。假设这样做是合法的:

struct S
{
    template<typename T> 
    T x;
};
int main()
{
    S s;
    s.x = ????
}

S的类型必须是已知的才能执行S s;,它不能神奇地改变以适应您决定给予x的任何类型。事实上,您甚至无法评估s.x

为了解决您的问题,您必须使模板参数成为包含数据成员的类的模板参数,例如:

template<typename T>
struct S
{
    vector<T> vec;
};
int main()
{
    S<int> s;
    s.vec = vector<int>(5);
}

Vector总是需要一个类T作为模板。但是模板应该放在类声明之前。

你可能是指

template<class T> 
class A {
private:
std::vector<T> vec;
};