标准::数组<T>初始化
std::array<T> initialization
std::array<T>
本质上是一个封装在struct
中的C样式数组。struct
s的初始化需要大括号,数组的初始化也需要大括号。所以我需要两副背带:
std::array<int, 5> a = {{1, 2, 3, 4, 5}};
但我看到的大多数示例代码只使用了一对大括号:
std::array<int, 5> b = {1, 2, 3, 4, 5};
为什么允许这样做?与第一种方法相比,它有什么好处或缺点吗?
好处是您可以。。。较少输入。但缺点是,只有当声明具有该形式时,才允许省略大括号。如果省略=
,或者如果数组是成员并使用member{{1, 2, 3, 4, 5}}
初始化它,则不能只传递一对大括号。
这是因为在f({{1, 2, 3, 4, 5}})
中,当大括号被传递给函数时,人们担心可能会出现过载歧义。但它引起了一些讨论,并产生了一份问题报告。
本质上,= { ... }
初始化总是能够省略大括号,就像中一样
int a[][2] = { 1, 2, 3, 4 };
这不是什么新鲜事。新的是,您可以省略=
,但必须指定所有大括号
int a[][2]{ {1, 2}, {3, 4} };
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 在C和C++中初始化结构中的数组
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 在函数内部的声明中初始化数组,并在外部使用它
- 继承:构造函数,初始化C++11中基类的类C数组成员