c – 内存损坏与std :: initializer_list
发布时间:2020-12-16 05:58:34 所属栏目:百科 来源:网络整理
导读:参见英文答案 C++11 initializer list fails – but only on lists of length 22 我的代码中有内存损坏: #include string#include iostream#include vector#include initializer_listint main() { std::vectorstd::initializer_liststd::string lists = { {
参见英文答案 >
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中具有调试输出.你会看到像: lists.size()= 2 因为initializre_list不包含std :: string对象的副本,它们(临时std :: string objects0刚刚创建并销毁之前的’;’ 例如,参考std :: string对象 std :: cout<<的std :: string( “17”); 但是,如果您在示例中将std :: string替换为“const char *”,则所有应用都可以正常工作. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |