运算符=:返回引用与值
Operator=: return reference vs. value
我经历了这一切,有点困惑。假设我将一个类声明为:
class cls
{
public:
int x;
cls(int _x):x(_x){}
cls& operator=(cls& ob)
{
x = ob.x;
return *this;
}
};
然后创建2个对象并执行复制操作,然后将赋值运算符重载前后两个变量的地址打印为:
cls o1 = 7;
cls o2 = cls(8);
cout<<&o1<<endl; //0330F880
cout<<&o2<<endl; //0330F874
o1 = o2;
cout<<&o1<<endl; //0330F880
cout<<&o2<<endl; //0330F874
两个地址组是相同的;这被理解为赋值运算符通过引用返回。
但我注意到,如果我将赋值运算符定义为按值返回,则会返回相同的地址组值。
在上面提到的链接中,如果按值返回,则会返回对象的副本。那么为什么它返回相同的地址值呢。他们不应该有所不同吗。请帮我理清思路。
返回值只有在您使用它执行某些操作时才相关。例如:
(o1 = o2).do_something();
或者等效地:
(o1.operator=(o2)).do_something();
do_something()
方法将在返回的对象上运行——在您的情况下是o1
的原始实例,因为它返回了一个引用。但是,如果您更改代码以返回值,则do_something()
将在o1
的副本上运行。
如果您有第三个对象cls* o_ptr;
并执行以下操作:
cls o1 = 7;
cls o2 = cls(8);
cls* o_ptr = &(o1=o2);
如果显示o_ptr
,如果返回引用,则会看到它与&o1
相同,但如果返回值,则不同。
我认为,该地址是相同的,因为您只是覆盖结构的内部内容,而不是它在内存中的位置。
相关文章:
- 如何通过引用返回对象
- 函数如何使用引用返回所需的数字?
- 如何防止引用返回的私有结构的突变
- 如何在不使用临时变量的情况下取消引用返回指针的函数的返回值?
- 通过引用返回的变量的范围
- 对于具有引用返回类型的搜索算法,默认返回值应该是什么?
- 运算符重载C++类中的引用返回
- C++对象引用返回不同的值
- 解释通过从函数引用返回数组的语法
- 具有引用返回类型的重写方法上的协变返回类型无效
- 为什么在通过引用返回运算符分配时取消引用'this'指针?
- 为什么我在函数中使用引用并通过引用返回它仍然有效?
- 直接在 C++ 中将值分配给引用返回类型
- C++当您取消引用指向类对象的指针,然后将其作为引用返回时,是否可以对此引用调用方法
- 可以通过常量引用返回默认参数的值吗?
- 按值与右值引用返回
- 非常量引用返回函数在常量值返回函数上用作 r 值
- 当我使用按引用返回时,我不知道这些代码之间的区别
- 为什么通过引用返回向量比通过移动返回要快得多?
- 通过引用返回包含对象的向量