大括号初始化的细微之处

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).