为什么赋值初始化在不使用复制构造函数的情况下需要复制构造函数
Why initialization by assignment needs copy constructor if it does not use it
考虑以下代码:
class X {
int a;
public:
X(int a) : a(a){std::cout<<"in constructor";}
// X(const X& x) : a(x.a){std::cout<<"in copy constructor";}
X(const X& x) = delete;
X& operator=(const X& x) {
std::cout<<"in assignment";
a = x.a;
return *this;
}
};
int main(int argc, char *argv[]) {
X x = X(5);// error: `use of deleted function`
return 0;
}
给出一个错误:use of deleted function
。然而,如果我取消注释复制构造函数并删除delete
行,它会正常工作,但不使用复制构造函数(输出为:in constructor
)。
那么如果X x = X(5);
行在定义时不使用复制构造函数,为什么它在删除时尝试使用它?
问题在你的main
:行
X x = X(5);
是复制初始化——它看起来像一个赋值操作符,但它在底层被复制构造函数取代。
按以下方式重写代码可以修复这个问题,因为它没有给编译器留下避免使用赋值操作符的选项:
X x1(3);
X x2(5);
x1 = x2;
演示。
相关文章:
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 当从函数参数中的临时值调用复制构造函数时
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 为什么需要复制构造函数,在哪些情况下它们非常有用
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么类中的ostringstream类型的成员会导致";调用隐含删除复制构造函数";错误
- 复制构造函数、赋值运算符C++
- std::ofstream 作为类成员删除复制构造函数?
- 复制构造函数C++无法正确复制指针
- 关于复制构造函数的一个棘手问题
- 为什么调用复制构造函数而不是移动构造函数?
- 填充上编译器生成的复制构造函数之间的不一致
- C++ 对象指针数组的复制构造函数
- C++ 基本 CTOR 说明 - 为什么不调用赋值/复制构造函数
- 防止在复制构造函数中隐式调用基构造函数
- 为用户定义的类正确调用复制构造函数/赋值运算符
- 具有已删除移动和复制构造函数的类的就地构造
- 复制构造函数隐式转换问题
- 复制构造函数中的递归调用