Пул памяти - Memory pool

Пулы памяти, также называемый распределение блоков фиксированного размера, это использование бассейны за управление памятью это позволяет распределение динамической памяти сравним с маллок или же C ++ с оператор новый. Поскольку эти реализации страдают от фрагментация из-за переменных размеров блоков не рекомендуется использовать их в система реального времени из-за производительности. Более эффективное решение - предварительное выделение нескольких блоков памяти одинакового размера, называемых пул памяти. Приложение может выделять, получать доступ и освобождать блоки, представленные ручки в время выполнения.

Много операционные системы реального времени использовать пулы памяти, такие как Средство обработки транзакций.

Некоторые системы, например веб-сервер Nginx, используйте термин пул памяти для ссылки на группу распределений переменного размера, которые впоследствии могут быть освобождены сразу. Это также известно как область, край; видеть региональное управление памятью.

Простая реализация пула памяти

Простой модуль пула памяти может выделить, например, три пула на время компиляции с размерами блоков, оптимизированными для приложения, развертывающего модуль. Приложение может выделять, получать доступ и освобождать память через следующий интерфейс:

  • Выделите память из пулов. Функция определит пул, в который входит требуемый блок. Если все блоки этого пула уже зарезервированы, функция пытается найти один в следующем более большом пуле (ах). Выделенный блок памяти представлен ручка.
  • Получите указатель доступа к выделенной памяти.
  • Освободите ранее выделенный блок памяти.
  • Ручка может, например, быть реализована с беззнаковое целое. Модуль может интерпретировать дескриптор внутри, разделив его на индекс пула, индекс блока памяти и версию. Пул и индекс блока памяти обеспечивают быстрый доступ к соответствующему блоку с помощью дескриптора, в то время как версия, которая увеличивается при каждом новом распределении, позволяет обнаруживать дескрипторы, блок памяти которых уже освобожден (вызванный дескрипторами, хранящимися слишком долго).

Пул памяти против malloc

Преимущества

  • Пулы памяти позволяют выделять память с постоянным временем выполнения. Освобождение памяти для тысяч объектов в пуле - всего одна операция, а не одна за другой, если маллок используется для выделения памяти для каждого объекта.
  • Пулы памяти могут быть сгруппированы в иерархические древовидные структуры, что подходит для специальных структур программирования, таких как петли и рекурсии.
  • В пулах блочной памяти фиксированного размера нет необходимости хранить метаданные выделения для каждого выделения, описывающие такие характеристики, как размер выделенного блока. Это обеспечивает значительную экономию места, особенно при небольших помещениях.
  • Обеспечивает детерминированное поведение в системах реального времени, избегая ошибок нехватки памяти.

Недостатки

  • Может потребоваться настройка пулов памяти для приложения, которое их развертывает.

Смотрите также

внешняя ссылка