在复制初始化上下文中'默认初始化'用C ++表示?

时间:2018-05-07 15:14:04

标签: c++ initialization c++14 overloading c++17

例如,我想我理解直接初始化(vs copy-)的上下文中的列表初始化 - int x{} vs int x = {}基本上。

但在cppreference我发现了这个:

  

当类类型的对象从相同或派生类类型的对象进行复制初始化,或者在复制初始化上下文中进行默认初始化时,候选函数都是转换正在初始化的类的构造函数。参数列表是初始化器的表达式。

我想我理解为什么候选人为第一种情况转换构造函数,而不是第二种情况。我的意思是,我不能写MyClass x = MyClass之类的内容,= MyClass()将是值初始化,而= MyClass(args...)将是直接启动。

即使存在这样的结构,我也不明白为什么一个临时的MyClass对象'构建'应特别包括所有转换构造函数。

(而x并不是我所看到的,因为它绝对是复制构造的,而不是默认构造的。)

所以我想我对这里的条款感到困惑。

2 个答案:

答案 0 :(得分:5)

这篇文字在P0398R0文章中添加,旨在描述以下案例:

Z c = {};

表示非汇总Z

答案 1 :(得分:-3)

这意味着,在初始化对象时,它不是默认构造的,然后使用赋值运算符复制,但始终根据初始化中给出的参数立即构造。因此,当您使用赋值表示法时,它仅使用转换。

实施例: 鉴于班级:

class MyClass
{
    MyClass();
    MyClass(int);
};

以下语句只调用MyClass :: MyClass(int)而没有默认构造函数。

MyClass obj = 10;
MyClass obj{10};
MyClass obj = {10};