С Новым годом! Форум программистов, компьютерный форум, киберфорум
C++
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.56/16: Рейтинг темы: голосов - 16, средняя оценка - 4.56
0 / 0 / 0
Регистрация: 22.12.2015
Сообщений: 1

Очень долгое освобождение динамически выделенной памяти

30.07.2012, 20:56. Показов 3451. Ответов 23
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Все никак не могу разобраться с одной проблеммой!
У меня есть отображение, в котором хранятся указатели на абстрактный класс Node
C++
1
 typedef  map <int num ,Node*> NodeCont;
.
C++
1
2
3
4
5
6
7
8
9
//Абстрактный класс узла
class Node
{
public:
    virtual ~Node()=0;
////
....
////
};
При работе программы создаются объекты классов-потомков класса Node (Node1, Node2, Node12) с помощью new, и в NodeCont заносятся указатели на них (всего заносится около 80 тысяч элементов).
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
typedef set<NodeCont::iterator,CompareObj> LinksCont;
 
//Узел 1
class Node1:virtual public Node
{
protected:
     LinksCont next_links;
public:
    ~Node1(){}
////
....
////
};
 
 
//Узел 2
class Node2:virtual public Node
{
protected:
     LinksCont prev_links;
public:
    ~Node1(){}
////
....
////
};
 
//Узел 12
class Node12:private Node1,public Node2
{
public:
    ~Node12(){}
////
....
////
};
Размеры контейнеров типа LinksCont в узлах Node1, Node2, Node12- небольшие, в среднем 2-3 элемента.

После наполнения отображения программа выполняет различные действия с этими объектами.
При завершении работы программы освобождается память, выделенная для объектов.
C++
1
2
3
4
5
6
7
8
    NodeCont::iterator iter=nodes.begin();
    NodeCont::iterator iter_end=nodes.end();
    while(iter!=iter_end)
    {
        //удаляем узел
        delete (*iter).second;
        ++iter;
    }
Тут и начинаются проблемы. Освобождение памяти занимает огромное время - раз в 100 большее, чем на работу всей программы (включая создание этого отображения).
В чем может быть проблема, как ускорить освобождение памяти?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
30.07.2012, 20:56
Ответы с готовыми решениями:

Освобождение динамически выделенной памяти
ОС Windows инициировала точку останова в TimeDelay2.exe. Это может быть вызвано повреждением кучи и указывает на ошибку в TimeDelay2.exe...

Ошибка при чистке динамически выделенной памяти
Всё выполняется, но при очистке памяти: for (j=0; j&lt;m; j++) delete aa; delete aa; for (j=0; j&lt;m; j++) delete ...

Ошибка при освобождении динамически выделенной памяти
Почему возникает ошибка при выделении памяти под buff при 2-й итерации? #include &lt;stdio.h&gt; #include &lt;string.h&gt; ...

23
 Аватар для Airhand
537 / 459 / 3
Регистрация: 08.07.2009
Сообщений: 2,625
06.08.2012, 19:01
Студворк — интернет-сервис помощи студентам
Постарел однако я. Времена DOS, Win 95/98 прошли, а я всё так же думаю. Лучший выход для ТС просто выйти из проги. Покажите нам деструктор, что там такого делаете ?
0
Эксперт С++
 Аватар для niXman
3211 / 1459 / 74
Регистрация: 09.08.2009
Сообщений: 3,441
Записей в блоге: 2
06.08.2012, 20:50
Цитата Сообщение от Airhand Посмотреть сообщение
Покажите нам деструктор
не покажет.
вопрос задал, и свалил.
0
0 / 0 / 0
Регистрация: 22.12.2015
Сообщений: 1
07.08.2012, 06:09
Цитата Сообщение от niXman Посмотреть сообщение
не покажет.
вопрос задал, и свалил.
Да, свалил - обстоятельства...
Деструкторы все пустые, в них ничего не происходит кроме автоматического удаления контейнеров next_links и prev_links.

Цитата Сообщение от yekka Посмотреть сообщение
а как это было установлено?
На глаз. Просто засек сколько по времени происходит вызов деструктора.

Хочу поделится версией того почему происходит медленное удаление. Я думаю, что это фрагментация динамической памяти.
Основной контейнер с указателями на объекты абстрактного класса создается в ходе работы программы. При этом происходит создание объектов Node1, Node2, Node12 с пустыми контейнерами next_links и prev_links. Также во время программы происходит постепенное заполнение подобных контейнеров в объектах Node1, Node2, Node12, причем заполняются эти контейнеры не сразу при создании объектов, а в совершенно разное время. Поэтому В ходе выполнения программы контейнеры next_links и prev_links сами динамически расширяются. В результате такого заполнения происходит фрагментация динамической памяти.
Такая моя версия.
В поддержку могу сказать, что если удалять элементы в контейнере с конца, то процесс удаления идет в несколько раз быстрее.

Добавлено через 21 минуту
Процесс удаления элементов происходит еще быстрее, если контейнеры next_links и prev_links в объектах Node1, Node2 и Node12 создавать сразу же и дальше не изменять их размер.
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
07.08.2012, 14:14
Не смог повторить:
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
#include <map>
#include <set>
#include <iostream>
 
//Абстрактный класс узла
class Node
{
public:
    virtual ~Node() {}
};
 
typedef std::map <int, Node*> NodeCont;
typedef std::set<NodeCont::iterator> LinksCont;
 
//Узел 1
class Node1: virtual public Node
{
protected:
     LinksCont next_links;
public:
    ~Node1(){}
};
 
 
//Узел 2
class Node2: virtual public Node
{
protected:
     LinksCont prev_links;
public:
    ~Node2(){}
};
 
 
int main(int argc, char **argv) {
  size_t size = 1000000;
  NodeCont storage;
  for (size_t i = 0; i < size; ++i)
    if (i % 2)
      storage[i] = new Node1();
    else
      storage[i] = new Node2();
  std::cout << "." << std::endl;
  for (NodeCont::iterator i = storage.begin(); i != storage.end(); ++i)
    delete i->second;
 
  return 0;
}
На глаз, создание объектов отрабатывает примерно столько же по времени, сколько и удаление.
Могу посчитать точно по времени, но будет не очень продуктивно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.08.2012, 14:14
Помогаю со студенческими работами здесь

Освобождение выделенной памяти
Здравствуйте! Есть структура, выглядит, например, так: struct some_structure { int* s; } *a = new some_structure; ...

Освобождение памяти, выделенной через new
Я прочитал, что память динамически для строки, можно выделить к примеру узнать длину строки strlen(tex) и нужно добавить единицу для...

Корректно ли освобождение выделенной памяти?
Извиняюсь, если такой вопрос уже звучал. Допустим есть такой кусок кода: struct A { int *x; } *b; void main() { b = new A;...

Массив: Освобождение выделенной памяти
Сказали переделать код, нужно что бы память освобождалась не в отдельной функции а как то по другому так и не понял как. #include...

Освобождение памяти, выделенной под массив
Выделяю память под массив: int (*array_1) = new int; как освободить то, что выделил? И еще вопрос: как указателю...


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

Или воспользуйтесь поиском по форуму:
24
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru