Evgenii Legotckoi
Evgenii Legotckoi18 вересня 2018 р. 04:01

Шаблони проектування, що породжують - Об'єктний пул

Голи

Об'єктний пул може значно підвищити продуктивність; він найбільш ефективний у ситуаціях, коли вартість ініціалізації екземпляра класу висока, а швидкість створення екземпляра класу висока, при цьому кількість екземплярів, що використовуються у будь-який момент часу, невелика.

Проблеми

Пули об'єктів (інакше звані пулами ресурсів) використовуються управління кешуванням об'єктів. Клієнт, який має доступ до пулу об'єктів, може уникнути створення нових об'єктів, просто попросивши пул про новий об'єкт, який вже було створено. Як правило, пул буде пулом, що росте, тобто сам пул буде створювати нові об'єкти, якщо пул порожній. Також ми можемо мати пул, який обмежує кількість створених об'єктів.

Бажано зберегти всі об'єкти, які повторно використовуються, які в даний час не використовуються в одному пулі об'єктів, щоб вони могли керуватися однією послідовною політикою. Щоб досягти цього, клас багаторазового пулу повинен реалізовувати шаблон проектування Сінглетон.


Обговорення

Пул об'єктів дозволяє іншим об'єктам «перевіряти» об'єкти зі свого пулу, коли ці об'єкти більше не потрібні їхнім процесам, вони повертаються в пул для повторного використання.

Тим не менш, ми не хочемо, щоб процес повинен був чекати виділення певного об'єкта, тому пул об'єктів також створює нові об'єкти в міру необхідності, але також повинен використовувати засіб для періодичного очищення об'єктів, що не використовуються.

Структура

Загальна ідея шаблону пула з'єднань полягає в тому, що якщо екземпляри класу можуть бути повторно використані, ви уникаєте створення екземплярів класу, повторно використовуючи їх.

  • Reusable . Примірники класів у цій ролі взаємодіють з іншими об'єктами протягом обмеженого періоду часу, потім вони більше не потрібні для цієї спільної роботи
  • Client . Примірники класів у цій ролі використовують багаторазові об'єкти.
  • ReusablePool. Примірники класів у цій ролі керують багаторазовими об'єктами для використання об'єктами Client.

Зазвичай бажано зберегти всі об'єкти, які повторно використовуються, які в даний час не використовуються в одному пулі об'єктів, щоб вони могли керуватися однією послідовною політикою. Тому клас ReusablePool призначений для Сінглетон класу. Його конструктор(и) є приватним, що змушує інші класи викликати метод getInstance для отримання одного екземпляра класу ReusablePool .

Об'єкт Client викликає метод acquireReusable об'єкта ReusablePool , коли потрібен об'єкт багаторазового використання. Об'єкт ReusablePool підтримує колекцію об'єктів багаторазового використання. Він використовує колекцію об'єктів, що повторно використовуються, щоб містити пул повторно використовуваних об'єктів, які в даний час не використовуються.

Якщо в пулі є об'єкти багаторазового використання, коли викликається метод acquireReusable , він видаляє об'єкт Reusable з пулу і повертає його. Якщо пул порожній, метод acquireReusable створює об'єкт повторного використання, якщо це можливо. Якщо метод acquireReusable не може створити новий об'єкт багаторазового використання, він чекає, поки об'єкт колекції повторно не повернеться до колекції.

Об'єкти Client передають об'єкт багаторазового використання методом releaseReusable у ReusablePool , коли вони припинили роботу з об'єктом. Метод releaseReusable повертає об'єкт багаторазового використання в пул повторно використовуваних об'єктів, які не використовуються.

У багатьох додатках у шаблоні проектування пул об'єктів існують причини обмеження загальної кількості об'єктів багаторазового використання, які можуть існувати. У таких випадках об'єкт ReusablePool, який створює об'єкти повторного використання, несе відповідальність за те, що він не створює більше об'єктів, ніж зазначена максимальна кількість об'єктів, що повторно використовуються. Якщо об'єкти ReusablePool несуть відповідальність за обмеження кількості об'єктів, що створюються, то клас ReusablePool матиме метод для вказівки максимальної кількості об'єктів, які будуть створені. Цей метод вказаний на наведеній вище діаграмі як setMaxPoolSize.

Приклад

Пула об'єктів нагадує офісний склад. Коли наймають нового співробітника, офіс-менеджер має підготувати йому робоче місце. Він підраховує, чи запасне обладнання на складі офісу. Якщо так, то офіс-менеджер використовує його. Якщо ні, то розміщує замовлення на придбання нового обладнання Amazon. У випадку, якщо працівника звільнено, його обладнання переміщається на склад, де його можна взяти, коли знадобиться нове робоче місце.

Контрольний список

  1. Створити клас ObjectPool з private масивом об'єктів усередині
  2. Створити acquire та release методи
  3. Переконайтеся, що ObjectPool працюватиме як синглетон

Емпіричні правила

  • Шаблон Factory Method може використовуватись для інкапсуляції логіки створення об'єктів. Проте після створення він не керує ними, шаблон пула об'єктів відстежує створені ним об'єкти.
  • Спів об'єктів зазвичай реалізується як Сінглетон
Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

Коментарі

Only authorized users can post comments.
Please, Log in or Sign up
Ua

Qt - Тест 001. Сигналы и слоты

  • Результат:84бали,
  • Рейтинг балів4
Ua

Qt - Тест 001. Сигналы и слоты

  • Результат:42бали,
  • Рейтинг балів-8
ОК

Qt - Тест 001. Сигналы и слоты

  • Результат:47бали,
  • Рейтинг балів-6
Останні коментарі
ИМ
Игорь Максимов22 листопада 2024 р. 11:51
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii Legotckoi31 жовтня 2024 р. 14:37
Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZE19 жовтня 2024 р. 08:19
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь Максимов05 жовтня 2024 р. 07:51
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas505 липня 2024 р. 11:02
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Дмитрий
Дмитрий03 лютого 2025 р. 06:24
Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
NW
Nayo Wai30 січня 2025 р. 09:22
не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
n
nkly03 січня 2025 р. 02:52
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
M
Marsel16 серпня 2023 р. 14:26
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Evgenii Legotckoi
Evgenii Legotckoi24 червня 2024 р. 15:11
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.

Слідкуйте за нами в соціальних мережах