我有一个作业,我必须写一个简单的类。该类必须保存字符串数组,并包含'+'操作符的重载,该操作符将两个数组的元素组合成一个新数组并返回该数组。
另外,这个函数必须是'const',这就是我遇到问题的地方。当试图改变类的"大小"属性和它所持有的数组,我得到错误。当尝试返回对象时,我也会得到一个错误。我理解前两个错误的原因是因为我已经声明了函数'const',但我的问题是,在const方法中重新分配这些值的正确方法是什么?
别对我太严厉了,我刚刚开始学习c++,这些概念对我来说有点新。我试着研究这个问题,但还没有找到任何有用的答案。话虽如此,我真的需要让这个功能工作,所以任何帮助将非常感激。
下面是类:
class FirstClass{
private:
string* sList;
unsigned int _size;
public:
FirstClass(const unsigned int initSize = 1);
// copy, assignment, and destructor
FirstClass& operator+(const FirstClass& add)const;
};
FirstClass::FirstClass(const unsigned int initSize):_size(initSize)
{
sList = new string[initSize];
return;
}
FirstClass& FirstClass::operator+(const FirstClass& add)
const{
if(add.sList){
int prevSize = this->_size;
this->_size += add._size; // can't do this
string newList[this->_size];
for(int a=0; a<prevSize; a++){
newList[a] = this->sList[a];
}
for(int b=0; b<add._size; b++){
sList[b+prevSize] = add.sList[b];
}
delete [] sList;
this->sList = newList; // or this
}
return *this; // or this
}
编辑:谢谢你的快速回复,并澄清了我正在做的事情。这是我修改后的代码。
FirstClass FirstClass::operator+(const FirstClass& add)
const{
FirstClass ma(this->_size + add._size);
if(add.sList){
for(int a=0; a<this->_size; a++){
ma.sList[a] = this->sList[a];
}
for(int b=0; b<add._size; b++){
ma.sList[b+this->_size] = add.sList[b];
}
}
return ma;
}
加法操作符应该返回一个新对象,而不是对其操作数之一的引用。对于A+B
,修改A
或B
,或返回对其中一个的引用是没有任何意义的。
考虑到这一点,很容易看出操作符如何可以是const。
FirstClass operator+(const FirstClass& rhs) const;
您可以实现一个变异的operator+=
,并根据它实现operator+
:
FirstClass& operator+=(const FirstClass& rhs);
FirstClass operator+(const FirstClass& rhs) const
{
FirstClass ret = rhs;
ret += *this;
return ret;
}
或作为非成员:
FirstClass operator+(const FirstClass& lhs, const FirstClass& rhs)
{
FirstClass ret = lhs;
ret += rhs;
return ret;
}
+操作符不应该返回对对象的引用,而应该返回一个新对象。不要混淆+()
和+=()
运算符。后者将操作应用于表达式的左值,而前者返回一个新对象。
你应该返回:
FirstClass FirstClass::operator+(const FirstClass& add) const
假设您可以理解为什么const
需求有意义。没有它,您将被允许修改隐式this
对象的任何变量,这是不允许的。编译错误恰恰是在告诉你:"看,你正在尝试修改大小,但你应该返回一个新对象,所以操作数不能被修改"。