【问题标题】:data member 'vec' cannot be a member template数据成员“vec”不能是成员模板
【发布时间】:2013-08-14 12:25:02
【问题描述】:

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

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

但是我得到以下错误:

data member 'vec' cannot be a member template

我做错了什么?

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

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

}

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

【问题讨论】:

  • 你想做什么? std::vector 需要一个模板参数,而您没有提供。
  • 我的错误贴错了
  • 它可以工作fine

标签: c++ templates vector


【解决方案1】:

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

你可能是说

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

【讨论】:

    【解决方案2】:

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

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

    或者一个函数:

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

    在创建类的实例时,不能使用template &lt;&gt; 语句。相反,您可以像这样指定模板参数:

    TemplateClass<int> tc;
    

    当调用模板函数时:

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

    【讨论】:

      【解决方案3】:

      这样的向量不能包含任何东西。

      假设编译器允许您声明这样的向量,然后您编写:

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

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

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

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

      无论如何,作为一种解决方法,您可以声明vector&lt;void*&gt; vec,以便向量可以包含指向您想要的任何内容的指针。

      【讨论】:

      • 是的,但是void * 会让他丢失所有类型信息。最好的方法是使用Variant(来自boost,或者实现你自己的)。
      • @MaximeOudot 我同意。 C++11 或 14 甚至支持 union 自定义 classes,无需使用其他库。
      【解决方案4】:

      此答案适用于 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);
      }
      

      【讨论】:

      • C++17 增加了对模板变量的支持
      • @Michael 实际上它们是在 C++14 中添加的
      猜你喜欢
      • 1970-01-01
      • 2015-04-14
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2023-04-02
      • 1970-01-01
      • 1970-01-01
      • 2023-03-23
      相关资源
      最近更新 更多