![]() |
![]() ![]() ![]() ![]() ![]() |
![]() |
Оптимизация объединения двух списков ключ-значение в Delphi: торговля памятью за скоростьDelphi , Базы данных , Сортировка и ФильтрВ статье мы рассмотрим проблему объединения двух списков ключ-значение в Delphi, где главным приоритетом является скорость выполнения этой операции. Для достижения высокой производительности мы будем готовы пожертвовать частью памяти. Проблема и требованияВ основе одного из наших приложений лежит функция объединения списков ключ-значение, которая вызывается очень часто. Поэтому она должна быть как можно быстрее. В качестве ввода мы получаем два списка ключ-значение, представленные в виде указателей на массивы символов. Например, Мое решениеВ основе моего решения лежит словарь, который сопоставляет ключ (строку) с указателем на память и длиной блока памяти, содержащего значение. Этот словарь отсортирован по ключам. Он может быть сброшен перед использованием и совместно использоваться при нескольких вызовах функции объединения, что позволяет экономить на выделении и освобождении памяти для словаря и его записей. Для каждого входного списка ключей-значений мы выполняем следующие действия:
После заполнения словаря мы строим выходную строку, перебирая словарь, конкатенируя ключ, разделитель ключа-значения, копию значения на основе заданной позиции и длины, и ОптимизацииЯ попробовал несколько вещей, измеряя производительность с помощью функции QueryPerformanceCounter Windows API. Оказалось, что даже с небольшим количеством ключей (два или три), поддержание отсортированного словаря дает почти такую же производительность. Сравнение ключей с помощью функции CompareString из Windows API было намного slower, чем извлечение ключей как строк и сравнение их с помощью CompareStr из SysUtils. Я предполагаю, что это происходит из-за более медленной реализации CompareString. Есть ли другой способ сравнить строки, который принимает указатели и длину в качестве входных данных? Я не нашел такой. Чтобы сохранить словарь отсортированным, я использую алгоритм сортировки из Classes.TStringList, который, как я понимаю, является быстрой сортировкой. Есть ли другой алгоритм сортировки, лучше подходящий для этой ситуации? Альтернативный ответВ основе нашего приложения лежит функция объединения списков ключ-значение. Так как эта функция вызывается очень часто, она должна быть как можно быстрее. Мы готовы пожертвовать частью памяти ради высокой производительности. Наше приложение написано на Delphi, но, я думаю, эта проблема может быть интересной независимо от используемого языка. Входные списки ключей-значений представлены в виде указателей на массивы символов. Например, В основе моего решения лежит словарь, который сопоставляет ключ (строку) с указателем на память и длиной блока памяти, содержащего значение. Этот словарь отсортирован по ключам. Он может быть сброшен перед использованием и совместно использоваться при нескольких вызовах функции объединения, что позволяет экономить на выделении и освобождении памяти для словаря и его записей. Для каждого входного списка ключей-значений мы выполняем следующие действия:
После заполнения словаря мы строим выходную строку, перебирая словарь, конкатенируя ключ, разделитель ключа-значения, копию значения на основе заданной позиции и длины, и Я попробовал несколько вещей, измеряя производительность с помощью функции QueryPerformanceCounter Windows API. Оказалось, что даже с небольшим количеством ключей (два или три), поддержание отсортированного словаря дает почти такую же производительность. Сравнение ключей с помощью функции CompareString из Windows API было намного slower, чем извлечение ключей как строк и сравнение их с помощью CompareStr из SysUtils. Я предполагаю, что это происходит из-за более медленной реализации CompareString. Есть ли другой способ сравнить строки, который принимает указатели и длину в качестве входных данных? Я не нашел такой. Чтобы сохранить словарь отсортированным, я использую алгоритм сортировки из Classes.TStringList, который, как я понимаю, является быстрой сортировкой. Есть ли другой алгоритм сортировки, лучше подходящий для этой ситуации? Подтвержденный ответНа данный момент ваше решение кажется хорошим и сложно будет его улучшить. Единственное предложение, которое я могу сделать, — использовать хеширование для словаря вместо отсортированного списка ключей и бинарного поиска. Вы можете использовать Delphi's `` TDictionary В статье рассматривается проблема объединения двух списков ключ-значение в Delphi, где главным приоритетом является скорость выполнения этой операции, и готово пожертвовать частью памяти ради высокой производительности. Комментарии и вопросыПолучайте свежие новости и обновления по Object Pascal, Delphi и Lazarus прямо в свой смартфон. Подпишитесь на наш Материалы статей собраны из открытых источников, владелец сайта не претендует на авторство. Там где авторство установить не удалось, материал подаётся без имени автора. В случае если Вы считаете, что Ваши права нарушены, пожалуйста, свяжитесь с владельцем сайта. :: Главная :: Сортировка и Фильтр ::
|
||||
©KANSoftWare (разработка программного обеспечения, создание программ, создание интерактивных сайтов), 2007 |
Время компиляции файла: 2024-12-22 20:14:06
2025-07-27 10:26:47/0.016118049621582/0