为什么默认构造函数是唯一使用的构造函数
Why is the default constructor the only one being used?
我试着看看这个例子中每个方法何时被调用:
#include <iostream>
using namespace std;
class A {
public:
int x;
A(int x) : x(x) {cout<<"default ctor"<<endl;}
A(const A& a) : x(a.x) {cout<<"copy ctor"<<endl;}
A& operator =(const A& a) {cout<<"assignment op"<<endl;x=a.x;return *this;}
};
A f() { return A(5); }
int main() {
A a = f();
}
我希望用语句return A(5)
调用复制构造函数,因为只要我知道返回对象时,就会创建并返回临时的副本。此外,在句子A a = f()
中,我希望复制构造函数也被调用,因为a
正在初始化,给定了另一个A
对象。
为什么要打印default ctor
?
这里有两个优化。返回值优化(RVO)Copy Elision将通过初始化将f()
的返回值直接合并到目标变量中。所以这个代码:
A f() { return A(5); }
A a = f();
优化为:
A a(5);
因为在的情况下允许c++编译器跳过operator=
A a = A();
A b = A(a);
并直接使用构造函数。他们还可以执行复制省略的返回值优化。
因此,最终您基本上拥有A a(5);
相关文章:
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 初始化具有非默认构造函数的std::数组项的更好方法
- 具有默认模板类型的默认构造函数的类型推导
- 如何使用非默认构造函数实例化模板化类
- 为什么不调用移动构造函数?(默认情况下只有构造器,没有别的)
- 有没有一种代码密度较低的方法来使用非默认构造函数初始化数组?
- 声明没有默认构造函数的字段
- 基类中的默认析构函数禁用子类中的移动构造函数(如果有成员)
- 没有默认构造函数作为模板参数的自定义比较器
- C++17 没有默认构造函数的地图放置(私有默认构造函数)
- 使用移动调用对等构造函数unique_ptr默认构造函数
- C++复制构造函数和默认构造函数
- 将向量从 N1 缩小到 N2 项,而不触发默认构造函数并仅使用 move 语义
- 构造函数默认公共和私有变量
- 类模板构造函数默认参数
- 构造函数默认参数
- C++模板构造函数默认参数
- 在c++中设置构造函数默认值
- c++构造函数默认参数
- C++构造函数默认值头文件