Понимание std::bad_alloc в классе C++

Я пытаюсь понять классы C++, создав класс для операций matrice. Я обнаружил ошибку дампа! Я получил следующую литературу от компилятора:

terminate called after throwing an instance of 'std:bad_alloc'
  what():  std::bad_alloc
Aborted (core dumped)

Вот мое программирование:

#include <stdio.h>
#include <cmath>
#include <iostream>
using namespace std;

void swap(double &a, double &b)
{
    double temp = a;
    a = b;
    b = temp;
}

class matric
{
public:
    int row;
    double *pData = new double[row *row];
    void input();
    void output();

    int InverseMatrix(matric m1);

    int det(matric m1);

    void multiply(matric m1, matric m2);

};
void matric::input()
{
    int i, j;
    cout << "enter the size of matrix:";
    cin >> row;
    cout << "enter the matrix:" << endl;

    for (i = 0; i < row; i++)
    {
        for (j = 0; j < row; j++)
        {
            cin >> pData[i * row + j];
        }
    }
}
void matric::output()
{
    int i, j;
    for (i = 0; i < row; i++)
    {
        for (j = 0; j < row; j++)
        {
            cout << pData[i * row + j] << "  ";
        }
        cout << endl;
    }
}
void matric::multiply(matric m1, matric m2)
{
    int j1 = 0, k1 = 0, j2 = 0, k2 = 0;

    for (j1 = 0; j1 < row; j1++)
    {
        for (k2 = 0; k2 < row; k2++)
        {
            *(pData + j1 * row + k2) = 0;
            for (k1 = 0; k1 < row; k1++)
            {
                *(pData + j1 * row + k2) += *(m1.pData + j1 * row + k1) * (*(m2.pData + j2 * row + k2));
                j2++;
            }
            j2 = 0;
        }
    }


}


int matric::InverseMatrix(matric m1)
{
    double *m = new double[row * row];
    double *ptemp, *pt = m;

    int i, j;

    ptemp = pData;
    for (i = 0; i < row; i++)
    {
        for (j = 0; j < row; j++)
        {
            *pt = *ptemp;
            ptemp++;
            pt++;
        }
    }

    int k;

    int *is = new int[row], *js = new int[row];

    for (k = 0; k < row; k++)
    {
        double max = 0;
        for (i = k; i < row; i++)
        {
            for (j = k; j < row; j++)
            {
                if (fabs(*(m + i * row + j)) > max)
                {
                    max = *(m + i * row + j);
                    is[k] = i;
                    js[k] = j;
                }
            }
        }

        if (0 == max)
        {
            return 1;
        }

        if (is[k] != k)
        {
            for (i = 0; i < row; i++)
            {
                swap(*(m + k * row + i), *(m + is[k]*row + i));
            }
        }

        if (js[k] != k)
        {
            for (i = 0; i < row; i++)
            {
                swap(*(m + i * row + k), *(m + i * row + js[k]));
            }
        }

        *(m + k * row + k) = 1 / (*(m + k * row + k));

        for (j = 0; j < row; j++)
        {
            if (j != k)
            {
                *(m + k * row + j) *= *((m + k * row + k));
            }
        }

        for (i = 0; i < row; i++)
        {
            if (i != k)
            {
                for (j = 0; j < row; j++)
                {
                    if (j != k)
                    {
                        *(m + i * row + j) -= *(m + i * row + k) **(m + k * row + j);
                    }
                }
            }
        }

        for (i = 0; i < row; i++)
        {
            if (i != k)
            {
                *(m + i * row + k) *= -(*(m + k * row + k));
            }
        }
    }

    int r;
    for (r = row - 1; r >= 0; r--)
    {
        if (js[r] != r)
        {
            for (j = 0; j < row; j++)
            {
                swap(*(m + r * row + j), *(m + js[r]*row + j));
            }
        }
        if (is[r] != r)
        {
            for (i = 0; i < row; i++)
            {
                swap(*(m + i * row + r), *(m + i * row + is[r]));
            }
        }
    }

    ptemp = pData;
    pt = m;
    for (i = 0; i < row; i++)
    {
        for (j = 0; j < row; j++)
        {
            *ptemp = *pt;
            ptemp++;
            pt++;
        }
    }
    delete []is;
    delete []js;
    delete []m;

    return 0;
}

int main()
{
    matric m1;
    m1.input();
    m1.output();

    matric m2;
    m2.input();
    m2.output();
    cout << "creating m3" << endl;
    matric m3;
    m3.input();
    m3.multiply(m1, m2);
    m3.output();

    matric m4;
    m4.InverseMatrix(m1);
    m4.output();

    return 0;
}

1 ответ

Решение

Сначала удалите инициализацию в вашем классе.

double *pData = new double[row *row];

сделать это только это

double *pData;

Затем создайте правильный конструктор для вашего класса, который будет инициализировать переменную row с 0 а также pData с NULL, Если вам это нужно, создайте конструктор, который получит размер вашей матрицы следующим образом

matric(int newSize) {
   // allocate memoty here
}
Другие вопросы по тегам