3

我有一个奇怪的问题。有一个结构向量。使用临时结构,我 push_back 到该结构向量。但是当我检查第一个成员的cnt时,我发现它已经改变了。任何的想法?(以下代码为简化版,但具有代表性)

struct Vector
{
  float *dim;

  Vector ()
  {
    dim = new float [3];
  }
};

struct Face
{
  float an_N, an_P;
  int P, N;
  Vector Af;
  float Ad;
  Vector cnt;
  float ifac;
  float mf;
};

std::vector <Face> face;

Face temp_face;

for (;;)
{
    temp_face.cnt.dim[0] = 0.f;
    temp_face.cnt.dim[1] = 0.f;
    temp_face.cnt.dim[2] = 0.f;

    for (int q=0; q<n_vtx_2D; ++q)
    {
        temp_face.cnt = temp_face.cnt + pt[vtx[q]] / n_vtx_2D;                
    }                 

    face.push_back(temp_face);
}

std::cout << face[0].cnt.dim[0] << std::endl;

输出

0.25

0

4

1 回答 1

5

默认编译器生成的复制构造函数(和赋值运算符)用于VectorFace(但最重要的是Vector)。由于代码重用了 的同一个实例Face,命名为,向量中的temp_face所有实例都指向同一个数组(因为将包含 的副本)。FacefaceFace.cnt.dimfacestemp_face

我看不出有任何理由在里面动态分配数组,Vector因为它是固定大小的。建议改为:

struct Vector
{
    float dim[3];
};

或者你需要为Vector. 请参阅什么是三法则?了解更多信息。

于 2012-09-22T21:43:59.480 回答