Читати книгу - "Занурення в патерни проектування, Олександр Швець"
Шрифт:
Інтервал:
Добавити в закладку:
Багато архітектур починаються із застосування Фабричного методу (простішого та більш розширюваного за допомогою підкласів) та еволюціонують у бік Абстрактної фабрики, Прототипу або Будівельника (гнучкіших, але й складніших).
Будівельник концентрується на будівництві складних об’єктів крок за кроком. Абстрактна фабрика спеціалізується на створенні сімейств пов’язаних продуктів. Будівельник повертає продукт тільки після виконання всіх кроків, а Абстрактна фабрика повертає продукт одразу.
Класи Абстрактної фабрики найчастіше реалізуються за допомогою Фабричного методу, хоча вони можуть бути побудовані і на основі Прототипу.
Абстрактна фабрика може бути використана замість Фасаду для того, щоб приховати платформо-залежні класи.
Абстрактна фабрика може працювати спільно з Мостом. Це особливо корисно, якщо у вас є абстракції, які можуть працювати тільки з деякими реалізаціями. В цьому випадку фабрика визначатиме типи створюваних абстракцій та реалізацій.
Абстрактна фабрика, Будівельник та Прототип можуть реалізовуватися за допомогою Одинака.
Також відомий як: BuilderБудівельник — це породжувальний патерн проектування, що дає змогу створювати складні об’єкти крок за кроком. Будівельник дає можливість використовувати один і той самий код будівництва для отримання різних відображень об’єктів.
ПроблемаУявіть складний об’єкт, що вимагає кропіткої покрокової ініціалізації безлічі полів і вкладених об’єктів. Код ініціалізації таких об’єктів зазвичай захований всередині монстроподібного конструктора з десятком параметрів. Або ще гірше — розпорошений по всьому клієнтському коду.
Створивши купу підкласів для всіх конфігурацій об’єктів, ви можете надміру ускладнити програму.
Наприклад, подумаймо про те, як створити об’єкт Будинок. Щоб побудувати стандартний будинок, потрібно: звести 4 стіни, встановити двері, вставити пару вікон та постелити дах. Але що робити, якщо ви хочете більший та світліший будинок, що має басейн, сад та інше добро?
Найпростіше рішення — розширити клас Будинок, створивши підкласи для всіх комбінацій параметрів будинку. Проблема такого підходу — величезна кількість класів, які вам доведеться створити. Кожен новий параметр, на кшталт кольору шпалер чи матеріалу покрівлі, змусить вас створювати все більше й більше класів для перерахування усіх можливих варіантів.
Аби не плодити підкласи, можна підійти до вирішення питання з іншого боку. Ви можете створити гігантський конструктор Будинку, що приймає безліч параметрів для контролю над створюваним продуктом. Так, це позбавить вас від підкласів, але призведе до появи іншої проблеми.
Конструктор з безліччю параметрів має свій недолік: не всі параметри потрібні протягом більшої частини часу.
Більшість цих параметрів буде простоювати, а виклики конструктора будуть виглядати монстроподібно через довгий список параметрів. Наприклад, басейн є далеко не в кожному будинку, тому параметри, пов’язані з басейнами, даремно простоюватимуть у 99% випадків.
РішенняПатерн Будівельник пропонує винести конструювання об’єкта за межі його власного класу, доручивши цю справу окремим об’єктам, які називаються будівельниками.
Будівельник дозволяє створювати складні об’єкти покроково. Проміжний результат захищений від стороннього втручання.
Патерн пропонує розбити процес конструювання об’єкта на окремі кроки (наприклад, побудуватиСтіни, встановитиДвері і т. д.) Щоб створити об’єкт, вам потрібно по черзі викликати методи будівельника. До того ж не потрібно викликати всі кроки, а лише ті, що необхідні для виробництва об’єкта певної конфігурації.
Зазвичай один і той самий крок будівництва може відрізнятися для різних варіацій виготовлених об’єктів. Наприклад, дерев’яний будинок потребує будівництва стін з дерева, а кам’яний — з каменю.
У цьому випадку ви можете створити кілька класів будівельників, які по-різному виконуватимуть ті ж самі кроки. Використовуючи цих будівельників в одному й тому самому будівельному процесі, ви зможете отримувати на виході різні об’єкти.
Різні будівельники виконають одне і те саме завдання по-різному.
Наприклад, один будівельник робить стіни з дерева і скла, інший — з каменю і заліза, третій — із золота та діамантів. Викликавши одні й ті самі кроки будівництва, у першому випадку ви отримаєте звичайний житловий будинок, у другому — маленьку фортецю, а в третьому — розкішне житло. Зауважу, що код, який викликає кроки будівництва, повинен працювати з будівельниками через загальний інтерфейс, щоб їх можна було вільно замінювати один на інший.
ДиректорВи можете піти далі та виділити виклики методів будівельника в окремий клас, що називається «Директором». У цьому випадку директор задаватиме порядок кроків будівництва, а будівельник — виконуватиме їх.
Директор знає, які кроки повинен виконати об’єкт-будівельник, щоб виготовити продукт.
Окремий клас директора не є
!Увага!
Сайт зберігає кукі вашого браузера. Ви зможете в будь-який момент зробити закладку та продовжити читання книги «Занурення в патерни проектування, Олександр Швець», після закриття браузера.