关于复制构造
About copy construct
class Wood {
public:
Wood();
Wood(const Wood&); //copy constructor
~Wood();
private:
string price;
};
Wood::Wood(const Wood& orig) {
price(orig.price); **//error, why?**
}
Wood::Wood(const Wood& orig) : price(orig.price) { //rigth
}
如果我使用构造初始化并且是正确的。但是,如果使用"price(orig.price)"并且会出错,为什么呢?
构造函数的函数体(左大括号和右大括号之间的部分)与任何其他函数的主体没有什么不同。 您是否希望编译:
std::string a, b;
a(b); // <--- this line?
不,当然不是。为了编译它,std::string
需要类似operator()
重载的东西,它需要另一个字符串。它没有那个。
初始化列表中的代码不同。初始化列表中的表达式不会像函数体内的表达式那样解释为普通语句。它们被解释为初始化(例如构造函数调用)。因此,在初始化列表中,以下内容:
: price(orig.price)
等效于这样的语句:
std::string price(orig.price);
除了不需要指定price
的类型,因为这已经在类定义中完成。
请注意,不能在构造函数体内执行成员初始化,因为当您到达那里时,所有成员都已初始化。这就是您需要初始化列表的原因。当然,您可以在构造函数主体中进行赋值:
price = orig.price;
但这与初始化不同。它不适用于某些类型(例如 const 成员、引用成员或没有默认构造函数的成员)。 对于某些类型,它的效率可能较低,因为您首先构造(使用默认构造函数),然后进行赋值。但对于许多类型来说,这并不重要,因为默认构造几乎不需要任何成本。
不正确的,因为价格已经构建好了。如果它已经构造,则不能调用它的复制构造函数。
你必须做一些类似 price = orig.price 的事情;
检查编译错误,你就会明白为什么。在成员初始值设定项列表中,price(orig.price)
是使用值 orig.price
price
直接初始化成员变量。在复制构造函数的主体中,price(orig.price)
是对接受std::string
的重载operator()
的调用 std::string
。由于没有这样的重载,因此会出现编译错误。
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 使用strcpy将char数组的元素复制到另一个数组
- 是否可以初始化不可复制类型的成员变量(或基类)
- 适用于大型数组的无复制线程安全环形缓冲区
- 复制构造函数优先于移动构造函数
- 复制<Interface>作用类似于值的类的shared_ptr
- 保证复制 elis 是否适用于函数参数?
- 复制 std::vector,但将 lambda 应用于每个元素
- 对C++所做的更改使复制初始化适用于具有显式构造函数的类
- 删除复制和复制转让 - 公共、私有还是受保护?
- 当涉及分配器时,是否有类似于复制和交换习惯用法的东西
- 移动构造函数相对于复制构造函数的优势是什么?复制构造函数使用bool来表示是复制还是移动
- 覆盖Windows复制(如复制/粘贴)功能
- C++ 矢量复制适用于一个向量,但不适用于另一个向量
- 我可以使用复制算法复制'set'中的'vector'元素吗?
- 复制省略和返回值优化相对于复制构造函数
- 不依赖于原始的c++复制数组
- 模板构造函数优先于普通复制和移动构造函数
- 作用于可移动但不可复制对象序列的变化STL算法的行为