参见英文答案 >
C++11 initializer list fails – but only on lists of length 22
我的代码中有内存损坏:
我的代码中有内存损坏:
#include <string> #include <iostream> #include <vector> #include <initializer_list> int main() { std::vector<std::initializer_list<std::string>> lists = { { {"text1"},{"text2"},{"text3"} },{ {"text4"},{"text5"} } }; int i = 0; std::cout << "lists.size() = " << lists.size() << std::endl; for ( auto& list: lists ) { std::cout << "lists[" << i << "].size() = " << lists[i].size() << std::endl; int j = 0; for ( auto& string: list ) { std::cout << "lists[" << i << "][" << j << "] = "<< string << std::endl; j++; } i++; } }
样品输出:
lists.size() = 2 lists[0].size() = 3 lists[0][0] = text10�j ����text2H�j ����text3`�j ����text4����text5��������q
问题出在std :: initializer_list.将std :: initializer_list更改为std :: vector可以解决问题.
问题是为什么内存损坏发生在std :: initializer_list?
解决方法
因为std :: string对象在此行之前被销毁:
int i = 0;
如果std :: string在其析构函数和ctors中具有调试输出.你会看到像:
std :: string :: string 5次,
std :: string ::〜string 5次
在那之后
lists.size()= 2
因为initializre_list不包含std :: string对象的副本,它们(临时std :: string objects0刚刚创建并销毁之前的’;’
例如,参考std :: string对象
在这样的表达中:
std :: cout<<的std :: string( “17”); 但是,如果您在示例中将std :: string替换为“const char *”,则所有应用都可以正常工作.