c++ - 重载运算符 + c++ eclipse

标签 c++ eclipse operators overloading

我正在尝试重载运算符 +。 重要的是,operator + 准确地获取了我想要它获取的数据,但是一旦我将它发送给 operator=,其中的所有指针由于某种原因都被删除了。

Movie& Movie:: operator+ (const Movie& other) {

Movie toReturn,toCheck;
Worker* toAdd;
std::list<Worker*>::iterator checkSecond;
length > other.getLength() ?  toReturn=*this, toCheck=other : toReturn =  
other , toCheck = *this;

//I WANT TO TAKE THE LONGER MOVIE, AND ADD THE WORKERS FROM THE SHORTER 
  MOVIE TO THAT MOVIE

if(toCheck.getNumOfWorkers() > 0 ) //LOOK FOR WORKERS IN SHORT MOVIE

{
for (checkSecond=toCheck.getWorkersInMovie().begin(); checkSecond != 
toCheck.getWorkersInMovie().end(); ++checkSecond)
           {
                toAdd= (*checkSecond);
                toReturn.addWorker(toAdd);
                toAdd = NULL;


            } //END FOR
    }
}
}

*this=toReturn;
cout << "this is what my new object has after +" <<endl; 
this->printMovie(); //PRINTS EXACTLY WHAT I EXPECT, WITH NEW WORKERS
return *this;

}

但是当我将它发送给 operator = 时,它并没有按预期被复制,比如说 worker 的数量是 0。 MOVIE BOTH = MOVIEFIRST + MOVIETOADD

Movie& Movie:: operator= (const Movie& other) {

WHEN IT GETS HERE, MOVIE OTHER GETS DELETED..
return *this;

}

复制构造函数在所有情况下都按预期工作:

Movie::Movie(const Movie& toCopy) {

  cout << "inside copy" << endl;
 *this=toCopy;
}

帮助...?

最佳答案

运算符 +A + B 之类的表达式调用。从语义上讲,这个表达式不应该改变 A 的状态,而是返回一个表示总和的新对象。

因此,重载 + 运算符的正确签名应该如下所示:

Movie Movie::operator+ (const Movie& other) const { }

如果你想避免创建这个临时对象,那么你不应该重载 + 运算符,而是重载 += 如下:

Movie& Movie::operator+= (const Movie& other) { }

由于 += 具有赋值语义,因此您可以修改对象。

遵循此规则将帮助您解决您在代码中遇到的问题。

关于c++ - 重载运算符 + c++ eclipse,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34103543/

相关文章:

operators - 在哪里可以找到 J 中所有运算符的列表

c++ - 如何从编号的txt文件中读取? (data1.txt、data2.txt 等)

C++ 从 parent 的 vector 中调用 child 的方法?

c++ - _beginthreadx 和套接字

eclipse - 在eclipse中查找该类来自哪个库

php - 引用——这个符号在 PHP 中是什么意思?

c++ - 是否可以指定一个空的 std::vector 作为默认参数?

java - 将对象传递给 rcp View

java - 未找到测试运行程序 'JUnit 4' 的测试

C++ operator setter ruby​​ 风格