Форум программистов, компьютерный форум CyberForum.ru

Динамическая матрица - C++

Восстановить пароль Регистрация
 
Rashmash
2 / 2 / 0
Регистрация: 04.04.2011
Сообщений: 75
28.04.2012, 01:43     Динамическая матрица #1
Здравствуйте, помогите найти ошибку в динамической матрице: у меня почему-то вызывается автоматически деструктор в программе, хотя мне это совсем не нужно. Вот код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
class Matrix
{
private:
    int* m;
    int n;
public:
    Matrix();
    Matrix(int* mat, int n);
    Matrix(const Matrix &mat);
    ~Matrix();
    
    
    Matrix operator+(const Matrix &mat2);
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
#include <iostream>
#include "Matrix.h"
#include <iomanip>
 
 
Matrix::Matrix()
{
    n=0;
    m = NULL;
    
}
 
Matrix::Matrix(int* mat, int size)
{
    n=size;
    m = new int[n];
    for (int i=0; i<n; ++i)
    {
        m[i] = mat[i];
    }
}
 
Matrix::Matrix(const Matrix& mat)
{
    n = mat.n;
    m = new int[n];
    for (int i=0; i<n; i++){
        m[i] = mat.m[i];
    }
}
 
Matrix::~Matrix()
{
    delete[] m;
    std::cout<<"Destruktor"<<std::endl;
}
 
Matrix Matrix::operator+(const Matrix &mat){
        Matrix ret;
        ret.m = new int[n];
        for (int i=0; i<n; ++i){
            ret.m[i] = m[i]+mat.m[i];
        }
        return ret;
    }
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
#include "Matrix.h"
 
int main()
{   
    std::cout<<"N: ";
    int size;
    std::cin>>size;
    int* arr1=new int[size];
    for (int i=0; i<size; i++){
        arr1[i] = i;
    }
    
    int* arr2=new int[size];
    for (int i=0; i<size; i++){
        arr2[i] = i+2;
    }
 
    Matrix a(arr1, size);
    a.Vypis();
    Matrix b(arr2, size); //Вот здесь он вызывает деструктор объекта a, хотя мне это совсем не нужно.
Как решить эту проблему? Заранее благодарен.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.04.2012, 01:43     Динамическая матрица
Посмотрите здесь:

динамическая матрица в си++ C++
Объясните динамическая матрица C++
Динамическая матрица C++
динамическая матрица C++
C++ двумерная динамическая матрица
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Gepar
 Аватар для Gepar
1173 / 529 / 20
Регистрация: 01.07.2009
Сообщений: 3,511
28.04.2012, 02:01     Динамическая матрица #2
Rashmash, деструктор там точно не вызывается (даже если бы вы напортачили где-то то максимум он вызвался бы перед указанной вами строкой). С кодом вроде внешне всё в порядке, разве что можете дать компилируемый исходник чтобы можно было собрать и увидеть если и правда деструктор ваш вызывается.
Rashmash
2 / 2 / 0
Регистрация: 04.04.2011
Сообщений: 75
28.04.2012, 02:13  [ТС]     Динамическая матрица #3
matrix3x3dynamic.rar вот я пишу в Visual Studio 2010. или вот выпишу три файла:
1. matrix.h:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#ifndef _MATRIX_
#define _MATRIX_
 
class Matrix
{
private:
    int* m;
    int n;
public:
    Matrix();
    Matrix(int* mat, int n);
    Matrix(const Matrix &mat);
    ~Matrix();
    
    void ZeroMatrix();
    void IdentityMatrix();
    Matrix operator+(const Matrix &mat2);
    void Vypis();
    
    
};
 
#endif
2. matrix.cpp:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
#include <iostream>
#include "Matrix.h"
#include <iomanip>
 
 
Matrix::Matrix()
{
    n=0;
    m = NULL;
    
}
 
Matrix::Matrix(int* mat, int size)
{
    n=size;
    m = new int[n];
    for (int i=0; i<n; ++i)
    {
        m[i] = mat[i];
    }
}
 
Matrix::Matrix(const Matrix& mat)
{
    n = mat.n;
    m = new int[n];
    for (int i=0; i<n; i++){
        m[i] = mat.m[i];
    }
}
 
Matrix::~Matrix()
{
    delete[] m;
    std::cout<<"Destruktor was here"<<std::endl;
}
 
 
 
void Matrix::ZeroMatrix()
{
    bool yes = true;
    for (int i=0; i<9; i++) 
    {
        if (m[i]!=0) 
        {
            std::cout<<"This is not a zero matrix"<<std::endl;
            yes = false;
            break;
        } 
    }
    if (yes) std::cout<<"This is a zero matrix"<<std::endl;
    
}
 
void Matrix::IdentityMatrix()
{
    int i,j,x=0;
    bool yes = true;
    for (i=0; i<3; i++)
    {
            for (j=0; j<3; j++)
        {
            if (i==j && m[x]!=1)
            {
                yes = false;
                break;
            } 
            if (i!=j && m[x]!=0)
            {
                yes = false; 
                break;
            }
            x++;
        }
 
    }
    if (yes) std::cout<<"This is identitymatrix"<<std::endl;
    else std::cout<<"This is not an identitymatrix"<<std::endl;
    
}
 
Matrix Matrix::operator+(const Matrix &mat){
        Matrix ret;
        ret.m = new int[n];
        for (int i=0; i<n; ++i){
            ret.m[i] = m[i]+mat.m[i];
        }
        return ret;
    }
 
void Matrix::Vypis() // vyvod na ekran
{
    for (int i=0; i<n; i++){
        std::cout<<m[i];
    }
}
3. main.cpp:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#include <iostream>
#include "Matrix.h"
 
int main()
{   
    std::cout<<"N: ";
    int size;
    std::cin>>size;
    
    int* arr1=new int[size]; //1 matrica
    for (int i=0; i<size; i++){
        arr1[i] = i;
    }
    
    int* arr2=new int[size]; //2 matrica
    for (int i=0; i<size; i++){
        arr2[i] = i+2;
    }
 
    Matrix a(arr1, size);
    a.Vypis(); //vyvod na ekran. После вывода появляется запись "destruktor" что свидетельствует о его вызове.
    Matrix b(arr2, size);
    
    Matrix c;
    c = a+b;
    c.Vypis();
    std::cout<<"Last";
    delete[] arr1;
    delete[] arr2;
    system("pause");
    return 0;
}
Rashmash
2 / 2 / 0
Регистрация: 04.04.2011
Сообщений: 75
28.04.2012, 02:20  [ТС]     Динамическая матрица #4
Кажется я что то напортачил с оператором +, потому что убирая его, деструктор не вызывается Но не знаю что там не правильно)

как понял в операторе + деструктор удаляет локальный объект "ret"; как сделать чтобы c = a+b работало правильно?)
gray_fox
What a waste!
 Аватар для gray_fox
1244 / 1127 / 53
Регистрация: 21.04.2012
Сообщений: 2,350
Завершенные тесты: 3
28.04.2012, 19:50     Динамическая матрица #5
Цитата Сообщение от Rashmash Посмотреть сообщение
Matrix c;
c = a+b;
Здесь вызывается конструтор по умолчанию, а потом - оператор присваивания, который вы не написали. Компилятор сгенерирует его за вас и будет утечка памяти. С operator + всё в порядке.
upd: точнее, логичнее было бы написать его так:
C++
1
2
3
4
5
6
7
Matrix Matrix::operator+(const Matrix &mat){
    Matrix ret(*this);
    for (int i=0; i<n; ++i){
        ret.m[i] += mat.m[i];
    }
    return ret;
}
Yandex
Объявления
28.04.2012, 19:50     Динамическая матрица
Ответ Создать тему
Опции темы

Текущее время: 17:38. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru