c – 内存损坏与std :: initializer_list

参见英文答案 > 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 *”,则所有应用都可以正常工作.

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...