c ++释放对象的校验和不正确 -

时间:2017-02-27 04:26:19

标签: c++

我收到此错误(内存位置因运行而异): 释放记忆! Image_Processing(6282,0x100091000)malloc: *对象错误0x1212121212121212:未释放指针被释放 * 在malloc_error_break中设置断点以进行调试

在这一点上它崩溃://删除m_data;

class Uint8Image {
public:
    uint32_t m_w;
    uint32_t m_h;
    uint8_t *m_data;


    Uint8Image(uint32_t w, uint32_t h): m_w(w), m_h(h), m_data(0)
    {
        m_data = new uint8_t(w*h);
    }

    Uint8Image(const Uint8Image &obj) ;

    Uint8Image& operator = (const Uint8Image &D ) {
        if(this != &D)
        {
            delete [] m_data;
            m_w= D.m_w;
            m_h = D.m_h;
            m_data=new uint8_t(m_w * m_h); // deep copy the pointer data
        }
        return *this;
    }

~Uint8Image()
    {
        std::cout << "Freeing memory!"<< std::endl;
    delete  m_data;   // it crashes here
    m_data = NULL;
    }

};

class MeniscusFinderContext {

public:

    MeniscusFinderContext( uint32_t m_a,  uint32_t m_b):

    {
      m_input_image = new Uint8Image(m_a,m_b);

    }

    ~MeniscusFinderContext()
    {
       delete m_input_image;
       m_input_image = NULL;

    }

Uint8Image m_input_image;};

//The function that calls:

//通过选项解析来获取输入,

int main(int argc, char *argv[]{
const char *file_name = options[INPUT].arg;

    std::ifstream file_stream(file_name,
                              std::ifstream::in | std::ifstream::binary);
    char buf[256];
    char *sEnd;
    file_stream.getline(buf, sizeof(buf));
    if(buf[0] != 'P' || buf[1] != '5') {
        std::cerr << "invalid input PGM file" << std::endl;
        return 1;
    }
    file_stream.getline(buf, sizeof(buf));
    while(buf[0] == '#') file_stream.getline(buf, sizeof(buf));
    uint32_t m_a = strtol(buf, &sEnd, 10);
    uint32_t m_b = strtol(sEnd, &sEnd, 10);

    MeniscusFinderContext M(m_a,m_b);


    file_stream.getline(buf, sizeof(buf));
    while(buf[0] == '#') file_stream.getline(buf, sizeof(buf));
    if(atoi(buf) != 255) return 3;
    file_stream.read((char *)M.m_input_image->m_data ,m_a * m_b);
    if(!file_stream) {
        std::cerr << "only got " << file_stream.gcount() << std::endl;
        return 2;
    }
    file_stream.close();
return 0;
}

编辑:我正在运行它,有时会运行,而其他人则会给我错误。似乎是随机顺序。任何提示都会非常有用。 我已经检查了堆栈溢出中的所有相关答案,但是无法弄明白。

1 个答案:

答案 0 :(得分:0)

new uint8_t(w*h);

这只分配了一个uint8_t,其初始值为w*h

您可能打算:

new uint8_t[w*h];

否则,这个:

file_stream.read((char *)M.m_input_image->m_data ,m_a * m_b);

会立即超出此缓冲区。在显示的代码中多次出现相同的错误。

delete  m_data;

分配有new[]的内容应使用delete[]解除分配。

通常,您的整体方法非常容易出错。而不是以这种方式手动处理内存,您应该使用std::vector和迭代器。正确使用C ++的容器大大降低了制造这类错误的可能性。