数据成员'vec'不能是成员模板
data member 'vec' cannot be a member template
为了声明包含模板的向量,我在标头中有以下两行:
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;
};
相关文章:
- 将成员变量添加到共享库中的类中,不会破坏二进制兼容性吗
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 具有奇怪重复模板模式的派生类中的成员变量已损坏
- 助记符和指向成员语法的指针
- 用于访问容器<T>数据成员的正确 API
- 内置函数可查看CPP中的成员变量
- 是否可以初始化不可复制类型的成员变量(或基类)
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 嵌套在类中时无法设置成员数据
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 将函数类成员映射到类本身内部
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 将Ref对象作为类成员
- 将包含C样式数组的对象初始化为成员变量(C++)
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 将公共但非静态的成员函数与ALGLIB集成
- 多成员Constexpr结构初始化
- 数据成员'vec'不能是成员模板