Структурные шаблоны проектирования - Фасад

шаблоны проектирования

Цели

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

Проблематика

Для сегмента клиентского доступа требуется упрощенный интерфейс для доступа к общей функциональности сложной подсистемы.

Обсуждение

Фасад испоьлзует инкапсуляцию сложной подсистемы внутри одного интерфейса. Это уменьшает кривую обучения, необходимую для успешного использования подсистемы. Это также способствует отвязыванию подсистемы от потенциально многих клиентов. С другой стороны, если Facade является единственной точкой доступа для подсистемы, это ограничит возможности и гибкость, которые могут потребоваться «опытным пользователям».

Объект Facade должен быть довольно простым посредником. Он не должен становиться всезнающим оракулом или «божественным» объектом.

Структура

Фасад принимает в себя «загадку, завернутую в загадку, окутанную тайной», и добавляет оболочку, которая приручает аморфную и непостижимую массу программного обеспечения для предоставления простого и понятного клиентского интерфейса.

SubsystemOne и SubsystemThree не взаимодействуют с внутренними компонентами SubsystemTwo. Они используют «фасад» SubsystemTwoWrapper (т. е. Абстракция более высокого уровня).

Пример

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

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

  1. Определите более простой унифицированный интерфейс для подсистемы или компонента.
  2. Создайте класс 'wrapper', который инкапсулирует подсистему.
  3. Фасад/обертка нивелирует сложность и взаимодействие с компонентом, делегируя соответствующие методы.
  4. Клиент использует (привязан к) только фасад.
  5. Подумайте, добавит ли  фасад дополнительные значения и функционал.

Эмпирические правила

  • Фасад определяет новый интерфейс, тогда как Adapter использует старый интерфейс. Помните, что адаптер поддерживает два существующих интерфейса, а не определяет совершенно новый.
  • В то время как Flyweight показывает, как сделать много маленьких объектов, Facade показывает, как сделать один объект, представляющий целую подсистему.
  • Посредник похож на Facade, поскольку он абстрагирует функциональность существующих классов. Посредник реферирует / централизует произвольные связи между объектами коллег. Напротив, Facade определяет более простой интерфейс для подсистемы, он не добавляет новых функций, и он не известен подсистемам.
  • Абстрактную фабрику можно использовать в качестве альтернативы Facade для скрытия классов, специфичных для платформы.
  • Объекты фасада часто являются синглтонами, потому что требуется только один объект Facade.
  • Адаптер и фасад - оба обертки; но это разные виды оберток. Целью Фасада является создание более простого интерфейса, и целью адаптера является разработка существующего интерфейса. Хотя Facade обычно обертывает несколько объектов, а Adapter обертывает один объект; Фасад мог бы иметь интерфейсный комплекс с одним сложным объектом, а адаптер мог бы обернуть несколько устаревших объектов.
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.
Поддержать автора Donate

Комментарии

Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
Как стать автором?

Внесите вклад в развитие сообщества EVILEG.

Узнайте, как стать автором сайта.

Изучить
Donate

Добрый день, Дорогие Пользователи !!!

Я Евгений Легоцкой, разработчик EVILEG. И это мой хобби-проект, который помогает учиться программированию другим программистам и разработчикам

Если сайт помог вам, и вы хотите также поддержать развитие сайта, то вы можете сделать пожертвование следующими способами

PayPalYandex.Money
Timeweb

Позвольте мне порекомендовать вам отличный хостинг, на котором расположен EVILEG.

В течение многих лет Timeweb доказывает свою стабильность.

Для проектов на Django рекомендую VDS хостинг

Посмотреть Хостинг Timeweb
g
29 мая 2020 г. 14:32
glushchenkoin

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:40баллов,
  • Очки рейтинга-8
АС
26 мая 2020 г. 11:29
Артём Сун-Дун-Чан

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:50баллов,
  • Очки рейтинга-4
МН
25 мая 2020 г. 11:33
Митя Нагибин

C++ - Тест 004. Указатели, Массивы и Циклы

  • Результат:50баллов,
  • Очки рейтинга-4
Последние комментарии
29 мая 2020 г. 13:00
Евгений Легоцкой

Django - Урок 023. Like Dislike система с помощью GenericForeignKey

Думал так, но похоже что нет. {{ post.votes.likes.user.username }} Это же QuerySet будет, а не отдельный единственный объект {% for vote in post.votes %} {{ vote.user.username …
29 мая 2020 г. 11:43
Владислав Меленчук

Django - Урок 023. Like Dislike система с помощью GenericForeignKey

А как получить имя пользователя, который поставил лайк? Думал так, но похоже что нет. {{ post.votes.likes.user.username }}
29 мая 2020 г. 6:30
Евгений Легоцкой

Qt/C++ - Урок 039. Как закрасить строку в QSqlTableModel по значению в столбце

У меня работает. Исправлял в проекте, который приложен к статье. А что происходит в вашем коде, с учётом места вызова этого кода, я знать не могу ;) Дебажьте и добавляйте условия, кото…
МА
29 мая 2020 г. 6:27
Михаил А

Qt/C++ - Урок 039. Как закрасить строку в QSqlTableModel по значению в столбце

QModelIndexList rowIndexes = ui->tableView->selectionModel()->selectedRows(); model->removeRows(rowIndexes.first().row(), rowIndexes.size()); model-&…
Сейчас обсуждают на форуме
31 мая 2020 г. 6:57
Алексей Внуков

Минимальный размер Item

считайте по размеру включенных элементов, чтоб все помещалась. например у вас всего 2 кнопки, тогда минимальный размер итема будет ширина 1-й кнопки + ширина 2-й кнопки + отступы, и точно также …
f
31 мая 2020 г. 2:24
fryn3

Можно ли сделать в QML таблицу как в Excel?

Можно ли сделать в QML таблицу как в Excel или как сделано в QTableView? Что бы можно было выделять диапазон ячеек, переключатся по таб, изменять размеры строк и столбцов. В QT 5.14 по…
S
РС
30 мая 2020 г. 11:49
Руслан Склюев

QML Как при нажатии на кнопку изменить название окна?

У меня три файла: 1. QML - это Loader и Window 2. QML вход в программу - страница Loader (там есть Switch) 3. QML - MainMenu. Мне нужно в (1), чтобы если на (2) Switch.enable, то …
ДК
29 мая 2020 г. 13:27
Джон Кофи

QMap<> какой ключ лучше

это ясно. Вопрос в том, как быстро мапа будет отрабатывать, если ключом будет QModelIndex. Какой параметр индекса возьмет за ключ. И вот насколько это будет медленнее или быстрее, чем QString пр…
О нас
Услуги
© EVILEG 2015-2020
Рекомендует хостинг TIMEWEB