有人可以解释以下示例中使用双大括号和单大括号初始化之间的行为差异吗?
代码 #1:
vector<string> v = {"a", "b"};
string c(v[0] + v[1]);
cout << "c = " << c;
cout << "c.c_str() = " << c.c_str();
输出 #1:
c = ab
c.c_str() = ab
代码 #2:
vector<string> v = {{"a", "b"}};
string c(v[0] + v[1]);
cout << "c = " << c;
cout << "c.c_str() = " << c.c_str();
输出 #2:
c = aacke�Z
c.c_str() = a
隐式转换中心。这就是正在发生的事情。
-
vector<string> v = {"a", "b"};
通过提供包含两个元素的初始值设定项列表来初始化向量。两个std::string
从字符串文本初始化,然后复制到向量中。 -
vector<string> v = {{"a", "b"}};
通过为初始值设定项提供一个元素来初始化向量。单个std::string
是从具有两个元素的初始值设定项初始化的。访问向量的第二个元素具有未定义的行为。
现在,这是有趣的部分。您的第二个代码段甚至在您访问 v[1]
之前就具有未定义的行为。重载分辨率(构造单个std::string
)选取构造函数。最可行的是:
template< class InputIt >
basic_string( InputIt first, InputIt last,
const Allocator& alloc = Allocator() );
InputIt
被推导出为char const [2]
(和函数参数调整,将其转换为char const*
)。由于这些不是真正的迭代器,所以所有的地狱都松动了。