shared_ptr 因为make_shared导致的crash问题

2 篇文章 0 订阅

这个问题第一次遇到,感觉比较奇怪,大致的代码如下

void png::read(const std::string& fname) {
    using chnk_ptr=void (*)(uint32_t, std::shared_ptr<char>);

    static const std::unordered_map<std::string, chnk_ptr> chnk_lut = {
        { "IHDR", png::chnk_ihdr },
        { "PLTE", png::chnk_plte },
        { "IDAT", png::chnk_idat },
    };

    FILE * fp = fopen(fname.c_str(),"rb");;


    if (!fp)
        return;

    // magic png header
    char b_hdr[8];
    fread(b_hdr, sizeof(b_hdr),1,fp);

    if (std::memcmp("\x89\x50\x4e\x47\x0d\x0a\x1a\x0a", b_hdr, 8) != 0)
        return;

    // read chunks
    // assuming none are incomplete
    while (!feof(fp)) {
        char b_len[4], b_type[5];

        std::memset(b_type, 0, sizeof(b_type));

        if(fread(b_len, 4,1,fp) !=1)
            return;
        if(fread(b_type, 4,1,fp) !=1)
            return;

        uint32_t c_len = big32(b_len);

        std::cout << "hit chunk of size: " << c_len << std::endl;

        std::shared_ptr<char> b_data = std::make_shared<char>(c_len);
        if(fread(b_data.get(), c_len,1,fp) != 1)
            return;

        // ignore crc
        fseek(fp, 4, std::ios_base::cur);

        // check if chunk is in lut, if so call it
        auto cback = chnk_lut.find(static_cast<char*>(b_type));

        if (cback != chnk_lut.end())
            (cback)->second(c_len, b_data);
    }

    m_val = true;

    fclose(fp);
}

这是个解析png图像的代码,但是使用make_shared会莫名其妙的报segmentfault,vs下报wrote to memory after end of buffer运行时错误,但是换成用new的方式构造shared_ptr就是好的,不知道是为啥

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值