微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

原文地址:https://www.jb51.cc/c/113148.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐