c++中为什么赋值运算符重载返回类型是引用
为什么赋值运算符重载返回类型是引用,而加号的重载返回值是对象?如:Cdemo&operator=(CDemo&a);(对对象之间的赋值运算重载)CComplexopera...
为什么赋值运算符重载返回类型是引用,而加号的重载返回值是对象?
如:Cdemo &operator=(CDemo &a);(对对象之间的赋值运算重载)
CComplex operator +(CComplex &c);(对复数之间加法的重载)
能不能写的稍微具体点,辛苦了,分数我会追加的 展开
如:Cdemo &operator=(CDemo &a);(对对象之间的赋值运算重载)
CComplex operator +(CComplex &c);(对复数之间加法的重载)
能不能写的稍微具体点,辛苦了,分数我会追加的 展开
5个回答
2015-08-07 · 知道合伙人数码行家
可以叫我表哥
知道合伙人数码行家
向TA提问 私信TA
知道合伙人数码行家
采纳数:25897
获赞数:1464984
2010年毕业于北京化工大学北方学院计算机科学与技术专业毕业,学士学位,工程电子技术行业4年从业经验。
向TA提问 私信TA
关注
展开全部
一、c/c++赋值运算符的本意为“返回左值的引用”(左值:赋值号左面的变量而非其值)
例:
int a, b = 3, c = 2;
(a = b) = c;
cout<<a<<endl;
对于a = b(a,b均为对象时),若不返回左值的引用,将会生成临时对象。如果不处理a = b = c这样的表达式,也会正常(只是会调用拷贝构造函数和析构函数处理临时对象)。
二、为了进行连续赋值,即 x = y = z
1、赋值返回引用
x = y = z 先执行y = z,返回y的引用,执行x = y
2、赋值不返回引用
x = y = z 先执行y = z,返回用y初始化的临时对象(注意临时对象都是常对象),再执行x = y的临时对象(要求operator=(const X&) ),返回用x初始化的临时对象(此处要求拷贝构造函数必须为X(const X&) )。
所以也并非必须返回引用,返回引用的好处既可以于赋值的原始语义已知,又可避免拷贝构造函数和析构函数的调用。
例:
int a, b = 3, c = 2;
(a = b) = c;
cout<<a<<endl;
对于a = b(a,b均为对象时),若不返回左值的引用,将会生成临时对象。如果不处理a = b = c这样的表达式,也会正常(只是会调用拷贝构造函数和析构函数处理临时对象)。
二、为了进行连续赋值,即 x = y = z
1、赋值返回引用
x = y = z 先执行y = z,返回y的引用,执行x = y
2、赋值不返回引用
x = y = z 先执行y = z,返回用y初始化的临时对象(注意临时对象都是常对象),再执行x = y的临时对象(要求operator=(const X&) ),返回用x初始化的临时对象(此处要求拷贝构造函数必须为X(const X&) )。
所以也并非必须返回引用,返回引用的好处既可以于赋值的原始语义已知,又可避免拷贝构造函数和析构函数的调用。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这只是个协议,适用于所有赋值相关运算符,所有内置类型和标准库类型都这样遵循,具体可参考Effective C++ 第三版 条款10 令 operator= 返回一个 reference to *this
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不要一定非要是引用的,用引用是为了可以写A+B+C这样的连续表达式
返回的不是引用或指针则只能用于赋值
返回的不是引用或指针则只能用于赋值
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
markmarkmarkmark
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询