我想确保我正确地理解了逐值传递与逐引用的关系。特别是,我正在查看对象增量++运算符的前缀/后缀版本。
假设我们有下面的类X
class X{
private:
int i;
public:
X(){i=0;}
X& operator ++ (){ ++i; return *this; } //prefix increment
X operator ++ (int unused){ //postfix increment
X ret(*this);
i++;
return ret;
}
operator int(){ return i; } //int cast
};首先,我是否正确地实现了前缀/后缀增量运算符?
第二,与前缀操作符相比,后缀操作符的内存效率如何?具体来说,在使用操作符的每个版本时,创建了多少个X对象副本?
对按引用返回与按值返回的确切情况的解释可能有助于我理解。
编辑:例如,使用以下代码..。
X a;
X b=a++;...are a和b现在化名了?
发布于 2010-07-05 18:02:46
在后缀增量中调用对象本身的前缀增量更符合惯例:
X operator++(int)
{
X copy(*this);
++*this; // call the prefix increment
return copy;
}因此,增量X对象的逻辑仅包含在前缀版本中。
https://stackoverflow.com/questions/3181211
复制相似问题