c – 内存损坏与std :: initializer_list

前端之家收集整理的这篇文章主要介绍了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&C++相关文章