Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/18: Рейтинг темы: голосов - 18, средняя оценка - 4.78
187 / 172 / 38
Регистрация: 03.08.2012
Сообщений: 596

Std::vector и утечки памяти

24.06.2016, 21:39. Показов 3775. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Проблема проявляется исключительно на Linux
При заполнении любого контейнера большим количеством данных с последующим уничтожением контейнера остается занято приличное количество памяти.

Пример кода:
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
#include <unistd.h>
#include <time.h>
#include <vector>
#include <string>
 
class ShrinkToFitTest {
public:
    ShrinkToFitTest() {
        for(int i = 0; i < 7000000; i++)
            m_list.push_back("111111111111111111");
    }
 
    ~ShrinkToFitTest() {
        m_list.clear();
        m_list.shrink_to_fit();
    }
 
private:
    std::vector<std::string> m_list;
};
 
int main(int argc, char* argv[]) {
    ShrinkToFitTest *a = new ShrinkToFitTest();
    delete a;
 
    sleep(10000);
    return 0;
}
Тестировалось с gcc 4.9.2 и gcc 6.1. ОС - Fedora

Памяти занято при gcc 4.9.2 - ~400 мб VIRT и RES
При gcc 6.1 - ~200мб VIRT и RES

Очистка кеша вручную не помогает

Заранее благодарен за возможные решения

P.S. На винде таких проблем не возникает
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.06.2016, 21:39
Ответы с готовыми решениями:

Std::vector push_back vs emplace_back
Бывают ли случаи, когда push_back невозможно реализовать через emplace_back, либо такая реализация будет неэффективна?

std::vector доступ по индексу vs доступ по итератору
std::vector&lt;int&gt; tmp; int i = 0; tmp.resize(1000000); std::vector&lt;int&gt;::iterator it = tmp.begin(); for (int m = 0;...

Освобождение памяти после std:bind
Что имею: - CentOS - gcc 4.8 - valgrind Что делаю - С помощью valgrind устраняю утечки - Если приложение остановлено...

7
923 / 639 / 198
Регистрация: 08.09.2013
Сообщений: 1,693
25.06.2016, 09:48
Лучший ответ Сообщение было отмечено Flassie как решение

Решение

Flassie, это особенности работы с паматью в libc.
Процесс не отдает память системе на тот случай, что она еще понадобится.
Сисшная malloc_trim(0) должна помочь.
Частично (не думаю, что значительно) может помочь освобождение каждой строки.
1
Псевдослучайный
1946 / 1146 / 98
Регистрация: 13.09.2011
Сообщений: 3,215
25.06.2016, 10:33
Проблема в фрагментации кучи.
Стандартный аллокатор из glib возвращает системе свободные страницы только с её вершины. То есть если, условно говоря, выделить двести метров памяти, потом ещё пять и опять двести, а затем высвободить оба больших блока, то системе вернется только последний из них. Это _не_ утечка памяти в прикладном её понимании, т.к. аллокатор будет выделять место в первом пустом блоке при новых вызовах.
Понять, что за данные остались в куче после того, как(казалось бы) всё высвобождено, можно запустив valgrind --leak-check=full --show-leak-kinds=all :
Code
1
2
3
4
5
6
7
8
9
10
11
12
==12864== HEAP SUMMARY:
==12864==     in use at exit: 72,704 bytes in 1 blocks
==12864==   total heap usage: 70,020 allocs, 70,019 frees, 9,791,304 bytes allocated
==12864== 
==12864== 72,704 bytes in 1 blocks are still reachable in loss record 1 of 1
==12864==    at 0x4C2ABD0: malloc (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==12864==    by 0x4EC193F: pool (eh_alloc.cc:123)
==12864==    by 0x4EC193F: __static_initialization_and_destruction_0 (eh_alloc.cc:250)
==12864==    by 0x4EC193F: _GLOBAL__sub_I_eh_alloc.cc (eh_alloc.cc:326)
==12864==    by 0x400F4A9: call_init.part.0 (in /usr/lib/ld-2.23.so)
==12864==    by 0x400F5BA: _dl_init (in /usr/lib/ld-2.23.so)
==12864==    by 0x4000DC9: ??? (in /usr/lib/ld-2.23.so)
Это служебные данные самого аллокатора. Место под список выделенных фрагментов, вероятно.

Если это необходимо, то бороться с таким поведением можно использованием более другого аллокатора.
1
187 / 172 / 38
Регистрация: 03.08.2012
Сообщений: 596
25.06.2016, 11:01  [ТС]
Цитата Сообщение от NoMasters Посмотреть сообщение
Если это необходимо, то бороться с таким поведением можно использованием более другого аллокатора.
Можно уточнить на эту тему?

Добавлено через 18 минут
Цитата Сообщение от gng Посмотреть сообщение
Сисшная malloc_trim(0) должна помочь.
Да, неожиданно, но помогло. Огромное спасибо
0
 Аватар для Olej
322 / 170 / 24
Регистрация: 25.03.2012
Сообщений: 712
25.06.2016, 18:03
Цитата Сообщение от Flassie Посмотреть сообщение
Проблема проявляется исключительно на Linux
Проблема проявляется как-раз в том, что вы переносите в Linux дурные привычки, приобретённые в другом месте (Windows).
Определитесь с тем, что вы называете "утечка памяти" и чем вы её меряете.

По стандартам возвращаемая процессом динамически полученная ранее память не обязана сразу же возвращаться в систему. Она остаётся за процессом, чтобы не дёргать память вперёд-назад на случай (вероятный) следующих размещений.
Это никак не считается утечкой памяти.
0
187 / 172 / 38
Регистрация: 03.08.2012
Сообщений: 596
25.06.2016, 23:05  [ТС]
Цитата Сообщение от Olej Посмотреть сообщение
Проблема проявляется как-раз в том, что вы переносите в Linux дурные привычки, приобретённые в другом месте (Windows).
Дурные привычки - привычная очистка памяти с помощью delete/free?)
Ну вы уж извините)
А когда приложение впустую занимает приличный объем памяти - это не очень нормально, как по мне

Хотя в некоторых случаях, отрицать не стану, это полезно
0
 Аватар для Olej
322 / 170 / 24
Регистрация: 25.03.2012
Сообщений: 712
25.06.2016, 23:18
Цитата Сообщение от Flassie Посмотреть сообщение
А когда приложение впустую занимает приличный объем памяти - это не очень нормально, как по мне
Это как по вам... А как по разработчикам операционных систем - это очень даже нормально . Особенно в многозадачных ОС: когда где-то памяти будет не хватать - вот тогда у вас немедленно её и отберут.
P.S. Вы должны при этом ещё принимать во внимание такие вещи, не очень заметные с уровня пользовательского программирования, как: MMU, отображение логических страниц на физическую память, выделение физической памяти только и исключительно страницами ... и др. подобные вещи.

Цитата Сообщение от Flassie Посмотреть сообщение
Дурные привычки - привычная очистка памяти с помощью delete/free?)
Я ни слова не сказал ни про delene ни про free.
Дурные привычки это: а). изучать программирование в Windows + б). переносить полученные в Windows стереотипы на другие (нормальные) системы.
0
1443 / 1326 / 131
Регистрация: 20.03.2009
Сообщений: 4,689
Записей в блоге: 11
02.07.2016, 15:03
Цитата Сообщение от Flassie Посмотреть сообщение
А когда приложение впустую занимает приличный объем памяти - это не очень нормально, как по мне
Вообще то ОС умеет выгружать редко используемые страницы памяти на HDD/SSD и т.д. Поэтому и есть VIRT и RES.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.07.2016, 15:03
Помогаю со студенческими работами здесь

Не могу разобраться как обновить в std::map<std::string, вектор_структур>
Не могу разобраться как обновить вектор структур после его добавления в map без удаления и перезаписи struct pStruct { int...

std::string, std::fstream, ошибка кучи
где то начало вылетать при операции += с локальной переменной std::string. Заменил на свой qString. Замечательно, то же самое... ошибка при...

Как обращаться к vector<vector>?
добрый день не подскажите, как обращаться к такой структуре: vector&lt;vector&lt;pair&lt;bool, string&gt;&gt;&gt; v; v....

Битовые утечки при записи данных на диск
Доброго дня форумчане! Сорри если оффтоп но... Пишу в консольке на C++ (MSVCE 2010) различные движки по расчетам и тут столкнулся с...

Разделить vector<string> на два vector<string>
У меня есть vector&lt;string&gt; line_from_file; line_from_file.resize(N); N-некое число Когда я встречу точку &quot;.&quot; в...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
PowerShell Snippets
iNNOKENTIY21 11.11.2025
Модуль PowerShell 5. 1+ : Snippets. psm1 У меня модуль расположен в пользовательской папке модулей, по умолчанию: \Documents\WindowsPowerShell\Modules\Snippets\ А в самом низу файла-профиля. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru