例如,我想我理解直接初始化(vs copy-)的上下文中的列表初始化 - int x{}
vs int x = {}
基本上。
但在cppreference我发现了这个:
当类类型的对象从相同或派生类类型的对象进行复制初始化,或者在复制初始化上下文中进行默认初始化时,候选函数都是转换正在初始化的类的构造函数。参数列表是初始化器的表达式。
我想我理解为什么候选人为第一种情况转换构造函数,而不是第二种情况。我的意思是,我不能写MyClass x = MyClass
之类的内容,= MyClass()
将是值初始化,而= MyClass(args...)
将是直接启动。
即使存在这样的结构,我也不明白为什么一个临时的MyClass
对象'构建'应特别包括所有转换构造函数。
(而x
并不是我所看到的,因为它绝对是复制构造的,而不是默认构造的。)
所以我想我对这里的条款感到困惑。
答案 0 :(得分:5)
答案 1 :(得分:-3)
这意味着,在初始化对象时,它不是默认构造的,然后使用赋值运算符复制,但始终根据初始化中给出的参数立即构造。因此,当您使用赋值表示法时,它仅使用转换。
实施例: 鉴于班级:
class MyClass
{
MyClass();
MyClass(int);
};
以下语句只调用MyClass :: MyClass(int)而没有默认构造函数。
MyClass obj = 10;
MyClass obj{10};
MyClass obj = {10};