Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 1
Регистрация: 01.10.2014
Сообщений: 87
1

Valgrind: mismatched free()/delete/delete[]

16.10.2015, 00:30. Показов 2237. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте. Имеется функция добавления элемента в дерево, которая работает правильно. А вот при удалении, когда рекурсия доходит вниз непосредственно до удаления узла, происходит ошибка, описанная выше. В конце кол-в выделений памяти не равно кол-ву ее освобождений. Я ещё пробовал делать функцию Destroy для работы с двойными указателями, но там почему-то вечная рекурсия. Подскажите пожалуйста, в чем проблема.
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
struct Pair{
    char key[256];
    unsigned long long int value;
};
 
struct TNode{
    Pair pair;
    int height;
    TNode *right;
    TNode *left;
    TNode(Pair p) { pair=p; height=1; left=right=0; }
};
 
TNode *Insert(TNode *root, Pair p)
{
    if (!root)
    {
        root = new TNode(p);
        return root;
    }
    if (strcmp(root->pair.key,p.key)>0) root->left=Insert(root->left, p);
    else  if (strcmp(root->pair.key,p.key)<0) root->right=Insert(root->right, p);
    else {
        std::cout<<"Exist"<<std::endl;
        return root;
    }
}
 
void TreeDestroy(TNode *node)
{
    if (*node == NULL)
        return;
 
    if (node->left != NULL)
        TreeDestroy(node->left);
 
    if (node->right != NULL)
        TreeDestroy(node->right);
 
    delete node;
 
    node = NULL;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.10.2015, 00:30
Ответы с готовыми решениями:

с free в delete
Как эту функцию можно переписать с помощью delete? void A(int **p,int r){ int **pr; ...

Из malloc-free в new delete
Есть код с выделением памяти с помощью malloc, надо сделать с new delete Вроде сделал,...

Используя delete по указателю, возвращенному new [] или delete [] указателем, возвращаемым new
Помогите ответить на вопрос, не могу понять суть вопроса (правильно ли понимаю, что будет если...

Оператор delete(ошибка) - free(): invalid next size (fast): 0x098f7008 ***
Делаю некое подобие функции itoa: char* c_itoa(int,char*,int):Реализацию сделал так(упрощённый...

0
16.10.2015, 00:30
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
16.10.2015, 00:30
Помогаю со студенческими работами здесь

Какая разница между delete и delete[]
Нашел информацию на разных сайтах и всё равно остались вопросы. Я понимаю, что delete используется...

В чем разница между delete и delete[]?
а можете еще по подробней рассказать про delete, точнее даже delete, чем именно отличается delete...

В каких ситуациях как обозвать метод: free(), release(), delete() или remove()?
В разных программах по разному называют метод для освобождения памяти, но интересно как все-таки...

Чем отличается delete[] от delete?
чем отличается? delete mas от delete mas


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru