Создание быстродействующего распределителя памяти, для 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 |
|
|
BRE |
30.6.2009, 8:45
Сообщение
#2
|
Профессионал Группа: Участник Сообщений: 1112 Регистрация: 6.3.2009 Из: Ростов-на-Дону Пользователь №: 591 Спасибо сказали: 264 раз(а) Репутация: 44 |
Как я понял задачу. Есть несколько конфигурационных файлов в которых храниться информация для вектора. Порядок загрузки файлов может быть любым. Нужно сформировать вектор с определенной последовательность данных.
Известно, что неприемлемое время тратиться на resize вектора. Можно попробовать использовать QList. Т.е. читаем все файлы в отдельные списки, а после этого собрать общий список из маленьких, соблюдая необходимый порядок. Сложение QList операция быстрая, так же как и добавления в список элемента. |
|
|
AD |
30.6.2009, 9:03
Сообщение
#3
|
Профессионал Группа: Участник Сообщений: 2003 Регистрация: 4.2.2008 Из: S-Petersburg Пользователь №: 84 Спасибо сказали: 70 раз(а) Репутация: 17 |
Как я понял задачу. Есть несколько конфигурационных файлов в которых храниться информация для вектора. Порядок загрузки файлов может быть любым. Нужно сформировать вектор с определенной последовательность данных. Известно, что неприемлемое время тратиться на resize вектора. Можно попробовать использовать QList. Т.е. читаем все файлы в отдельные списки, а после этого собрать общий список из маленьких, соблюдая необходимый порядок. Сложение QList операция быстрая, так же как и добавления в список элемента. Есть ини-файл, в котором определено, какие-именно параметры следует выбирать из лог-файлов (бинарные файлы определенного формата, записанные авиа-приборами)! Данные этого ини-файла (описание параметров) считываются в вектор QVector<ParamDescr*>, ParamDescr - абстрактный класс, описывающий вид параметров (в общем виде - название параметра, адрес (в восьмеричной системе счисления), тип параметра). При чтении лог-файлов значения нужных параметров (сравниваются получаемые адреса) записываются по нужному индексу в вектор значений параметров (как раз в params)! Что именно делать с QList, как и что складывать я не совсем понял. Можешь пояснить, пожалуйста? Если что-то в коде запишешь, буду благодарен. |
|
|
Текстовая версия | Сейчас: 28.1.2025, 20:42 |