0

我有一个指向对象的指针列表。我想要做的是读取列表并将每个对象存储在该对象类型的动态数组中。所以我这样做:

int size = List.size();  // find how many objects in the list
ClassA* object = new ClassA[size];   // create a dynamic array
int counter = 0;
p = List.begin();   // iterator = begining of the list
while( p != List.end() )
{
    object[counter] = (*p)->operator=(*(*p));
                // called like this as this function is in a separate class
    p++;
    counter++;
}

这似乎是我想要的,这意味着我需要赋值运算符,但我对放入其中的内容有点困惑,并且出现堆栈溢出错误,这是我认为我需要做的:

 ClassA ClassA::operator =(const ClassA& source)
 {
     ClassA* newObject;
     newObject = new ClassA;
     newObject = source;
     return newObject;

 }

这是一堆废话,我不知道,但在我的脑海里,这就是我想要它做的,但我不完全理解我是如何实现它的。

如果有人可以提供帮助或建议更好的方法来实现我所需要的,将不胜感激。

这样做的原因是存储在此列表中的对象通常会遍历每一帧并复制到临时对象中。但是在程序运行过程中列表并没有改变,这意味着我不需要复制每一帧,只需在开始时复制一次。而且我需要一个动态数组,因为我不知道列表中将存储多少对象。

4

1 回答 1

2

这可能是一个operator=实现:

ClassA &ClassA::operator =(const ClassA& source) {
    // check for self-assignment
    if(this != &source) {
        // copy instance variables.
        a = source.a; // for example...
    }
    // assignment always returns the lvalue
    return *this;
}

我不知道你ClassA的实例变量,所以你应该实现内部复制。

另一方面,在迭代列表时,您可以通过以下方式复制对象:

object[counter] = (**p);

(**p)返回,首先存储在迭代器中的指针,然后取消引用它。

于 2012-04-29T16:51:49.240 回答