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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
 
Buildog
40 / 40 / 2
Регистрация: 29.04.2012
Сообщений: 185
#1

Утечка памяти - C++

12.11.2012, 18:39. Просмотров 1047. Ответов 27
Метки нет (Все метки)

Доброго времени суток, форумчане. Помогите справиться с утечкой памяти, не понятно где зараза засела. Это класс представления числа в СОК (система остаточных классов) На вход подается лишь одно число и возникает проблема, если это (число < 2310) то всё нормально и отлично, при этом получается 6 остатков, но как только (число >= 2310), тогда количество остатков становится больше 6, и выбивает исключение об утечки памяти, после оператора return в main.cpp


C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include "SOK.h"
#include <iostream>
 
using namespace std;
 
void main ()
{
    int number=0;
    cout<<"Enter number=";
    cin>>number;
    SOK numb (number);
    numb.Show();
    system ("pause");
    return;
}
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#ifndef _SOK_H
#define _SOK_H
 
class SOK
{
public:
    SOK(int number);
    SOK ();
    ~SOK();
    int Show () const;
    void ChangeNumb (int Numb);
    SOK (const SOK &);
 
private:
    void Create (int n);
    int *pOsnova;
    int *pOstatok;
    int NumbCount;
};
 
#endif
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
98
99
100
101
102
103
104
#include "SOK.h"
#include <iostream>
 
using namespace std;
 
SOK::SOK()
{
    int NumbC = 1;
    ChangeNumb (NumbC);
    pOstatok = new int [NumbC];
    pOsnova = new int [NumbC];
    pOsnova[0]=0;
    pOstatok[0]=0;
}
 
SOK::SOK (int n)
{
    Create(n);
}
 
SOK::~SOK ()
{
    delete []pOstatok;
    pOstatok = 0;
    delete []pOsnova;
    pOsnova=0;
}
 
int SOK::Show () const
{
    if (pOsnova[0] == 0 && pOstatok[0]== 0)
    {
        cout << 0 << endl;
        return 0;
    }
    int P=1;
    int NUMBER = 0;
    int Count = 0;
    Count = NumbCount;
    for (int i = 0; i<Count; i++)
    {
        P *= pOsnova[i];
    }
    int *B = new int (Count);
    int z = 0;
    for (int i = 0; i < Count; i++)
    {
        z = 0;
        z = B[i] = P/pOsnova[i];
        while (B[i]%pOsnova[i] != 1)
        {
            B[i] += z;
        }
    }
    for (int i = 0; i < Count; i++)
    {
        NUMBER += B[i] * pOstatok [i];
    }
    while (true)
    {
        if (NUMBER < 0) 
        {
            NUMBER += P;
            cout << NUMBER << endl;
            return NUMBER;
        }
 
        NUMBER -= P;
    }
}
 
void SOK::ChangeNumb (int Numb)
{
    NumbCount = Numb;
}
 
void SOK::Create (int n)
{
    if (n==0) 
    SOK();
    int A[]={2, 3, 5, 7, 11, 13, 17, 19};
    int NumbC = 0;
    int count = 1; 
    for (int i=0; i<sizeof(A)/sizeof(int); i++)
    {
        if (n>count)
        {
            count *= A[i];
            NumbC++;
        }
    }
    NumbC++;
    ChangeNumb (NumbC);
    pOstatok = new int [NumbC];
    pOsnova = new int [NumbC];
    cout<<"Ostatok { ";
    for (int i=0; i<NumbC; i++)
    {
        pOstatok[i]=n%A[i];
        pOsnova[i] = A[i];
        cout<<pOstatok[i]<<" ";
    }
    cout<<"}"<<endl;
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
12.11.2012, 18:39
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Утечка памяти (C++):

Утечка памяти - C++
Подскажите, где здесь может возникать утечка памяти? Вроде везде, где можно - чищу... ///////////////////////////////////// // It's...

Утечка памяти - C++
Либо я себе мозг запудрила, либо помогите мне :) есть у меня вектор vector&lt;char*&gt; names_variable; дополняю его таким образом ...

Утечка памяти - C++
Здравствуйте. Есть программа (разбитая на функции) постоянно работающая в цикле и выводящая информацию на консоль. И получается что она...

Утечка памяти - C++
Взял листинг кода из книги Стивен Прата Язык программирования С++. Меня терзают смутные сомнения нет ли здесь утечки памяти, указатель ...

Утечка памяти - C++
Доброго времени суток! Столкнулся с проблемой утечки памяти! Будь у меня маленькая программка, выловил бы легко, но в 2000 строк кода все...

утечка памяти - C++
доброго времени суток Уважаемые форумчане, помогите пожалуйста разобраться с утечками памяти есть массив с геометрическими фигурами. ...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Issues
430 / 365 / 37
Регистрация: 06.08.2012
Сообщений: 961
12.11.2012, 18:45 #2
Мне кажется, или нужно сначала присваивать 0, а потом удалять?
0
Buildog
40 / 40 / 2
Регистрация: 29.04.2012
Сообщений: 185
12.11.2012, 18:50  [ТС] #3
Дело не в деструкторе, я уверен в этом на 90%, а в функции Show, поскольку если я запускаю без неё, то всё нормально проходит.
0
Issues
430 / 365 / 37
Регистрация: 06.08.2012
Сообщений: 961
12.11.2012, 18:54 #4
C++
1
 int *B = new int (Count);
где удаление?
0
Buildog
40 / 40 / 2
Регистрация: 29.04.2012
Сообщений: 185
12.11.2012, 18:57  [ТС] #5
Строку это добавить не помешает, но дело не в этом указателе, я объявлял даже статичным массив этот, всё равно не помогло.
0
Issues
430 / 365 / 37
Регистрация: 06.08.2012
Сообщений: 961
12.11.2012, 19:03 #6
Ну не знаю... Вот вы два раза виделяете память для:
C++
1
2
pOstatok = new int [NumbC];
pOsnova = new int [NumbC];
0
Buildog
40 / 40 / 2
Регистрация: 29.04.2012
Сообщений: 185
12.11.2012, 19:04  [ТС] #7
Ну так память выделяется на 2 разных будущих массива и она потом в деструкторе освобождается, ошибку выбивает уже после того как прошел return, то есть после выполнения деструктора
0
Kuzia domovenok
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,925
Записей в блоге: 1
12.11.2012, 19:04 #8
Наверняка выход за пределы массива.
Я ставил точки останова в конструкторе, Create и деструкторе
вводил 6553 - вылетает, но
Удаляются точно те адреса, что были выделены. Значит память не терялась.
Наверняка выход за пределы массива.
К таким вещам:
C++
1
2
3
4
5
6
7
8
 for (int i=0; i<sizeof(A)/sizeof(int); i++)
    {
        if (n>count)
        {
            count *= A[i];
            NumbC++;
        }
    }
К таким вещам я крайне подозрительно отношусь. Проблема наверняка тут
0
Buildog
40 / 40 / 2
Регистрация: 29.04.2012
Сообщений: 185
12.11.2012, 19:08  [ТС] #9
Цитата Сообщение от Kuzia domovenok Посмотреть сообщение
Наверняка выход за пределы массива.
Я ставил точки останова в конструкторе, Create и деструкторе
вводил 6553 - вылетает, но
Удаляются точно те адреса, что были выделены. Значит память не терялась.
Наверняка выход за пределы массива.
К таким вещам:
C++
1
2
3
4
5
6
7
8
 for (int i=0; i<sizeof(A)/sizeof(int); i++)
    {
        if (n>count)
        {
            count *= A[i];
            NumbC++;
        }
    }
К таким вещам я крайне подозрительно отношусь. Проблема наверняка тут
Что именно тут может быть не так? И если ошибка здесь, то она почему то проявляется только тогда, когда если функция show ? Если это функции нет, то всё нормально с любыми числами в пределах диапазона. Убрал функцию Show из main.cpp, запустил с числом 6553, ничего не выбило, отлично отработало, а как только обратно решил использовать Show, тут же получил исключение
0
Issues
430 / 365 / 37
Регистрация: 06.08.2012
Сообщений: 961
12.11.2012, 19:13 #10
Buildog,
C++
1
int *B = new int (Count);
находится именно в Show, попробуйте в конце освободить память для него.

Добавлено через 54 секунды
Ведь там утечка тоже происходит.
0
Buildog
40 / 40 / 2
Регистрация: 29.04.2012
Сообщений: 185
12.11.2012, 19:13  [ТС] #11
Цитата Сообщение от SeregaC++ Посмотреть сообщение
Buildog,
C++
1
int *B = new int (Count);
находится именно в Show, попробуйте в конце освободить память для него.
Если бы в этом дело было, я бы давно исправил, строки освобождения памяти
C++
1
2
    delete []B;
    B = 0;
уже добавлены, а ошибка всё равно не исчезла
0
Kuzia domovenok
1891 / 1746 / 118
Регистрация: 25.03.2012
Сообщений: 5,925
Записей в блоге: 1
12.11.2012, 19:15 #12
а как насчёт delete[] B; в функции Show() ?
опоздал
0
Croessmah
Эксперт CЭксперт С++
13226 / 7498 / 845
Регистрация: 27.09.2012
Сообщений: 18,417
Записей в блоге: 3
Завершенные тесты: 1
12.11.2012, 19:20 #13
C++
1
2
3
4
void SOK::Create (int n)
{
    if (n==0) 
    SOK();
Добавлено через 2 минуты
Уберите Вызов конструктора в методе!!!
1
Buildog
40 / 40 / 2
Регистрация: 29.04.2012
Сообщений: 185
12.11.2012, 19:22  [ТС] #14
Цитата Сообщение от Croessmah Посмотреть сообщение
C++
1
2
3
4
void SOK::Create (int n)
{
    if (n==0) 
    SOK();
Добавлено через 2 минуты
Уберите Вызов конструктора в методе!!!
Убрал, всё равно исключение есть

HEAP[Lab1 SOK.exe]: Invalid address specified to RtlValidateHeap( 006B0000, 006BA070 )
Lab1 SOK.exe вызвал срабатывание точки останова.
0
Croessmah
Эксперт CЭксперт С++
13226 / 7498 / 845
Регистрация: 27.09.2012
Сообщений: 18,417
Записей в блоге: 3
Завершенные тесты: 1
12.11.2012, 19:22 #15
Цитата Сообщение от Buildog Посмотреть сообщение
Убрал, всё равно исключение есть
Киньте весь код, а то Вы так и будете её ловить!
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
12.11.2012, 19:22
Привет! Вот еще темы с ответами:

Утечка памяти - C++
Господа подскажите как узнать какая п̶а̶д̶л̶а̶ переменная жрет память? Или как посмотреть сколько вообще переменных и объектов находятся в...

Утечка памяти - C++
Помогите с кодом, вот написал реализацию стека по заданию. Преподаватель попросил проверить, верно ли я использую delete, ибо mas в классе...

Утечка памяти - C++
Здравствуйте! Я пишу длинную арифметику для целых чисел. Ниже - функция произведения чисел X и Y. Вопрос: произойдет ли утечка памяти, и...

Утечка памяти - C++
Где я допустил ее(утечку)? #define _CRT_SECURE_NO_WARNINGS #include &lt;iostream&gt; #include &lt;cstring&gt; #include &lt;string&gt; class...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
12.11.2012, 19:22
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru