我有一个指向对象的指针列表。我想要做的是读取列表并将每个对象存储在该对象类型的动态数组中。所以我这样做:
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;
}
这是一个BS的负载我没有,但在我脑海中,这是我想要它做的,但我不完全理解我是如何实现它。
如果有人可以提供帮助或建议更好的方法来实现我的需要,我们将不胜感激。
执行此操作的原因是存储在此列表中的对象通常会遍历每个帧并复制到临时对象中。但是在程序运行期间列表没有改变,这意味着我不需要复制每个帧,只在开始时复制一次。我需要一个动态数组,因为我不知道列表中将存储多少个对象。
答案 0 :(得分: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)
返回,首先是存储在迭代器中的指针,然后取消引用它。