大括号初始化的细微之处
Brace initialization subtleties
本文关键字:初始化 更新时间:2023-10-16
在尝试使用大括号初始化时,可以找到一个微妙之处,即使用 std::vector
时,如以下示例所示:
#include <iostream>
#include <string>
#include <vector>
using namespace std;
template <typename T>
void print(const char * msg, const vector<T>& v) {
cout << msg << endl;
cout << "Size: " << v.size() << endl;
for (size_t i = 0; i < v.size(); ++i) {
cout << "#" << (i+1) << ": " << v[i] << endl;
}
cout << "---------------------" << endl;
}
int main() {
vector<string> vs{3};
print("vector<string> vs{3};", vs);
vector<int> vi{3};
print("vector<int> vi{3};", vi);
}
输出为:
vector<string> vs{3}; Size: 3 #1: #2: #3: --------------------- vector<int> vi{3}; Size: 1 #1: 3 ---------------------
因此,在第一种情况下,(所谓的...)统一初始化初始化一个包含三个空字符串的向量,而在第二种情况下,它初始化一个只包含一个值为 3 的整数的向量。
除此之外,在使用新的大括号初始化样式时,还有其他"陷阱"和微妙之处需要考虑吗?
您似乎已经了解容器初始值设定项列表构造函数的贪婪性质。对于其他令人惊讶的"陷阱",请参阅此问答,我被这个绊倒了。
std::string{ 65, 'C' } // NOT 65 times 'C', but "AC" ('A' is 65th character).
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 在C和C++中初始化结构中的数组
- 标准是否使用多余的大括号(例如 T{{{10}}})定义列表初始化?
- 在函数内部的声明中初始化数组,并在外部使用它
- 继承:构造函数,初始化C++11中基类的类C数组成员