为什么会这样?运算符= 和复制构造函数
why is this happening ? operator= and copy constructor
我有以下类:
class CRectangle
{
CRectangle(string color);
CRectangle(CRectangle &origin);
/* Some more code */
};
而这个:
class CPlane
{
/* Some more code */
CRectangle boundingBox();
};
为什么我可以这样做?
:CRectangle rectangle1;
CRectangle rectangle2=rectangle1;
CRectangle rectangle3(rectangle1); //Copy constructor.
但我不能这样做:
CPlane plane;
CRectangle rectangle4=plane.boundingBox();
CRectangle rectangle5(plane.boundingBox()); //Copy constructor.
如果我需要我最后一个工作,我该怎么做?我想这可能与操作员=
有关,但我并不确切知道。
编辑:修复复制构造函数。 错误仍然存在。
复制构造函数的第一个语法 请求编译器用于无限递归。
它应该是:-
CRectangle(const CRectangle& origin);
其次,两个调用都应该正常工作,因为两者都是对复制构造器的调用。
CRectangle rectangle4=plane.boundingBox();
CRectangle rectangle5(plane.boundingBox());
不能将右值绑定到非const
左值引用。
CRectangle rectangle3(rectangle1);
这里的rectangle1
是一个非const
的左值,所以这很好。
CRectangle rectangle5(plane.boundingBox());
plane.boundingBox()
是一个纯右值(prvalue(,因此CRectangle&
不能绑定到它。
而是声明复制构造函数以采用const
引用:
CRectangle(CRectangle const&);
或者另外声明一个移动构造函数(如果需要(。
相关文章:
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 当从函数参数中的临时值调用复制构造函数时
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 为什么需要复制构造函数,在哪些情况下它们非常有用
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么类中的ostringstream类型的成员会导致";调用隐含删除复制构造函数";错误
- 复制构造函数、赋值运算符C++
- std::ofstream 作为类成员删除复制构造函数?
- 复制构造函数C++无法正确复制指针
- 关于复制构造函数的一个棘手问题
- 为什么调用复制构造函数而不是移动构造函数?
- 填充上编译器生成的复制构造函数之间的不一致
- C++ 对象指针数组的复制构造函数
- C++ 基本 CTOR 说明 - 为什么不调用赋值/复制构造函数
- 防止在复制构造函数中隐式调用基构造函数
- 为用户定义的类正确调用复制构造函数/赋值运算符
- 具有已删除移动和复制构造函数的类的就地构造
- 复制构造函数隐式转换问题
- 复制构造函数中的递归调用