C++ 括号初始化的微妙之处
在尝试使用大括号初始化时,可以找到一个微妙之处,即使用C++ 括号初始化的微妙之处,c++,c++11,list-initialization,C++,C++11,List Initialization,在尝试使用大括号初始化时,可以找到一个微妙之处,即使用std::vector,如以下示例所示: #include <iostream> #include <string> #include <vector> using namespace std; template <typename T> void print(const char * msg, const vector<T>& v) { cout <<
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);
}
#包括
#包括
#包括
使用名称空间std;
模板
无效打印(常量字符*消息、常量向量和v){
cout您似乎已经理解了容器的初始值设定项列表构造函数的贪婪本质
std::string{ 65, 'C' } // NOT 65 times 'C', but "AC" ('A' is 65th character).
事实上,如果一个构造函数接受一个类型为initializer\u list
的参数,那么该构造函数是符合条件的……在VS2013中,MSVC的代码生成错误不会如此微妙:在C++11中,你不能通过带括号的init list复制初始化聚合,请参见。允许的转换中也有一个微妙之处,请参见例如。
std::string{ 65, 'C' } // NOT 65 times 'C', but "AC" ('A' is 65th character).