'default-initialization in copy-initialization context'在C++中是什么意思?
What does 'default-initialization in copy-initialization context' mean in C++?
例如,我想我理解直接初始化(与复制(上下文中的列表初始化是什么意思 - 基本上int x{}
与int x = {}
。
但是在cpp偏好上,我发现这个:
当类类型的对象从相同或派生类类型的对象进行复制初始化,或者在复制初始化上下文中进行默认初始化时,候选函数都是正在初始化的类的转换构造函数。参数列表是初始值设定项的表达式。
我想我理解为什么候选人要为第一种情况转换构造函数,而不是为第二种情况转换构造函数。我的意思是,我不能写像MyClass x = MyClass
这样的东西,= MyClass()
将是值初始化,= MyClass(args...)
将是直接启动。
即使存在这样的构造,我也不明白为什么临时MyClass
对象"构造"应该专门包括所有转换构造函数。
(正如我所看到的,这里没有讨论x
,因为它绝对是复制构造的,而不是默认构造的。
所以我想我对这里的术语感到困惑。
在论文P0398R0中添加了此措辞,旨在描述以下情况:
Z c = {};
对于非聚合Z
。
这意味着,当您初始化一个对象时,它不是默认构造然后使用赋值运算符复制的,而是始终立即从初始化中给出的参数构造。因此,当您使用赋值表示法时,它仅使用转换。
例: 给定类:
class MyClass
{
MyClass();
MyClass(int);
};
以下语句只调用 MyClass::MyClass(int(,没有默认构造函数。
MyClass obj = 10;
MyClass obj{10};
MyClass obj = {10};
相关文章:
- 为不同配置设置MSVC_RUNTIME_LIBRARY的正确方法是什么
- C++避免重复声明的语法是什么
- 在C++中,将大的无符号浮点数四舍五入为整数的最佳方法是什么
- 实现无开销push_back的最佳方法是什么
- C++从另一个类访问公共静态向量的正确方法是什么
- "throw expression code" 1e7 >返回 d 是什么?投掷标准::overflow_error( "too big" ) : d;意味 着?
- C++中名称篡改的目的是什么
- 在 c++ 中拥有一组结构的正确方法是什么?
- 这个指针和内存代码打印是什么?我不知道是打印垃圾还是如何打印我需要的值
- 是什么阻止DOMTimerCoordinator::NextID进入无休止的循环
- 派生类销毁的最佳实践是什么
- 这个语法std::class<>{}(arg1, arg2) 在C++中是什么意思?
- 通过JNI传递数据数组的最快方法是什么
- "using namespace std;"在C++的作用是什么?
- 在两台机器之间进行时间戳的最佳c++chrono函数是什么
- 文件系统:复制功能的速度秘诀是什么
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 使用QQuickFramebufferObject时同步数据的最佳方式是什么
- 是什么原因导致它无法编译?它是声明签名还是在函数本身的实现中
- 使用不同的CRT将新的C++代码与旧的(二进制)组件隔离开来的最佳方法是什么