运行时错误C ++程序:检测到glibc,munmap_chunk(),指针无效

时间:2013-05-05 20:18:28

标签: c++ glibc

我的C ++程序(使用矩阵处理一些计算,请参阅下面的文件)崩溃并显示以下消息:

  

*** glibc检测到*** ./matrix:munmap_chunk():指针无效:0x08bfd068 ***

后跟回溯和内存映射。当我第一次在Matrix类中调用set-Method时会发生这种情况 - 但我不知道我做错了什么...每个帮助(以及我的代码改进的一般提示)非常感谢!< / p>

Array.cpp

#include <iostream>
#include <stdlib.h>
#include <string.h>
#include "Array.h"

using namespace std;

Array::Array(){
    Array(10);
}

Array::Array(int size){
    data = new int[size];
    memset(data, 0, sizeof(data));
    length = size;
}

Array::~Array(){
    delete [] data;
}

void Array::set(int pos, int value){
    if(pos < 0) pos = 0;
    if(pos >= length) pos = length-1;
    *(data + pos) = value;
}

int Array::get(int pos){
    if(pos < 0) pos = 0;
    if(pos >= length) pos = length-1;
    return *(data + pos);
}

void Array::print(){
    for(int i = 0; i < length; i++){
        cout << *(data + i) << "\t";
    }
    cout << endl;
    return;
}

/*works only for arrays of length 9*/
int Array::find_max(int data[]){
    int max = data[0];

    for(int i = 1; i < 9; i++){
        if(data[i] > max) max = data[i];
    }

    return max;
}

Matrix.h

#ifndef MATRIX_H
#define MATRIX_H
#include "Array.h"

class Matrix{

    private:
        Array * data;
        int height;
        int width;

    public:
        Matrix();
        ...
};

#endif

Matrix.cpp

#include <iostream>
#include <stdlib.h>
#include <string.h>
#include "Matrix.h"

using namespace std;

Matrix::Matrix(){
    Matrix(10, 10);
}

Matrix::Matrix(int h, int w){
    height = h;
    width = w;

    data = new Array(height);

    for(int i = 0; i < height; i++){
        *(data + i) = *(new Array(width));
    }

}

Matrix::~Matrix(){
    for(int i = 0; i < height; i++){
        Array * row = (data + i);
        delete row;
    }

    delete data;
}

void Matrix::set(int h, int w, int value){
    Array row = *(data + h);
    row.set(w, value);
}

...

的main.cpp

#include <iostream>
#include <stdlib.h>
#include <string.h>
#include "Array.h"
#include "Matrix.h"

using namespace std;

int main(int argc, char** argv){
    if(argc != 3){
        cout << "usage: " << argv[0] << " <m> x <n>" << endl;
        exit(-1);
    }

    int m = atoi(argv[1]);
    int n = atoi(argv[2]);

    Matrix * myMatrix = new Matrix(m, n);

    /*fill matrix randomly*/
    int guess, minus;
    srand(time(NULL));

    for(int r = 0; r < m; r++){
        for(int c = 0; c < n; c++){
            guess = rand() % 1001;
            minus = rand() % 2;

            if(minus == 0) guess *= -1;
            std::cout << " set " << c << ", " << r << " " << guess << std::endl;
            myMatrix->set(r, c, guess);

        }
    }

    ...

    delete myMatrix;
    ...

    return 0;
}

1 个答案:

答案 0 :(得分:3)

Matrix::Matrix(){
    Matrix(10, 10);
}

这不符合您的想法。它只是创建一个临时矩阵并丢弃它。这意味着正在构建的Matrix的高度,宽度和数据未在那里初始化

我认为你的目的是做与Matrix::Matrix(int h, int w)中所做的相同的事情。但是你不能这样做。


如果你有 C ++ 11 支持,你可以使用delegated construction做同样的事情。

Matrix::Matrix() :  // <- Notice the colon
    Matrix(10, 10)
{
}

如果您没有C ++ 11支持,则必须手动执行

Matrix::Matrix(){
    height = 10;
    width = 10;

    data = new Array(height);

    for(int i = 0; i < height; i++){
        *(data + i) = *(new Array(width));
    }

}

或者您可以创建另一个成员函数来执行常见操作并从两个构造函数中调用它。


另一个问题

Array row = *(data + h);
row.set(w, value);

您正在将数组行复制到名为row的新数组中。 您没有复制构造函数。所以指针的值直接复制。 当函数返回时row被破坏,这意味着row.data指向的内存也是deleted,这意味着矩阵中的数据也会受到影响因为它指的是同一件事。请参阅The rule of three

应该是

Array* row = (data + h);
row->set(w, value);