Создание быстродействующего распределителя памяти, для std::vector или замена глобальных операций выделения памяти |
Здравствуйте, гость ( Вход | Регистрация )
Создание быстродействующего распределителя памяти, для std::vector или замена глобальных операций выделения памяти |
AD |
29.6.2009, 10:38
Сообщение
#1
|
Профессионал Группа: Участник Сообщений: 2003 Регистрация: 4.2.2008 Из: S-Petersburg Пользователь №: 84 Спасибо сказали: 70 раз(а) Репутация: 17 |
Раньше был обычный массив (динамический), который содержал значения определенных параметров, прочитанных из лог-файла (широта, долгота, скорость и пр.). Сейчас сделал в виде вектора. Вместо оператора new теперь использую resize. Но так как эти операции чересчур затратные (а цикл может содержать и 100000 итераций (где каждый раз происходит выделение)), то стало необходимо сделать алгоритм немного по-другому.
Выделять память блоками. Т.е. вместо след. операций: code1 Делать следующее: code2 При замене на QVector code1 перешел в следующий: code3
Как переписать code2 для использования в векторе QVector? Заранее благодарен за помощь.... Сообщение отредактировал AD - 30.6.2009, 15:08 |
|
|
Litkevich Yuriy |
29.6.2009, 17:52
Сообщение
#2
|
разработчик РЭА Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: 94 |
|
|
|
AD |
29.6.2009, 18:02
Сообщение
#3
|
Профессионал Группа: Участник Сообщений: 2003 Регистрация: 4.2.2008 Из: S-Petersburg Пользователь №: 84 Спасибо сказали: 70 раз(а) Репутация: 17 |
а её зачем распределять? Ты вектор даными заполняй и всё. Тогда я не понимаю как! В смысле? У меня идет такая штуковина:
Сообщение отредактировал AD - 29.6.2009, 18:03 |
|
|
BRE |
29.6.2009, 19:18
Сообщение
#4
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
AD, прости, а можешь словами рассказать, что нужно получить.
Почитал, но особо не врубился. При последовательном заполнении (чтении) все равно QList или QVector. Только QList не нужно resize'ить. |
|
|
AD |
29.6.2009, 22:01
Сообщение
#5
|
Профессионал Группа: Участник Сообщений: 2003 Регистрация: 4.2.2008 Из: S-Petersburg Пользователь №: 84 Спасибо сказали: 70 раз(а) Репутация: 17 |
code 1, code2 из первого примера - это рабочие коды. Он плохи тем, что при чтении большого количества лог-файлов (или же очень-очень большого лог-файла) на операцию выделения памяти тратится много времени, из-за чего загрузка длится дольше, чем хотелось бы и сжирает процессорное время! Хотелось бы, чтобы загрузка происходила быстрее. Вариант который можно сделать следующий: выделять память более большими блоками, а потом ее распределять между более мелкими массивами - модернизация code 3. Так как я вместо обычных массивов, стал пользоваться QVector, то хотелось бы получить аналогичный алгоритм для векторов!
P.S. Заполнение непоследовательное - вначале могут заполнить 20 элемент, а потом 1-ый! Сообщение отредактировал AD - 29.6.2009, 22:02 |
|
|
Текстовая версия | Сейчас: 28.1.2025, 20:45 |