Evgenii Legotckoi
Evgenii Legotckoi27. September 2018 05:11

Strukturelle Gestaltungsmuster - Fassade

Ziele

  • Bereitstellen einer einheitlichen Schnittstelle für eine Reihe von Schnittstellen in einem Subsystem. Eine Fassade definiert eine übergeordnete Schnittstelle, die die Verwendung des Subsystems erleichtert.
  • Umhüllen Sie ein komplexes Subsystem mit einer einfacheren Schnittstelle.

Probleme

Das Client-Zugriffssegment erfordert eine vereinfachte Schnittstelle, um auf die gemeinsame Funktionalität eines komplexen Subsystems zuzugreifen.


Diskussion

Eine Fassade kapselt ein komplexes Subsystem innerhalb einer einzigen Schnittstelle. Dies reduziert die Lernkurve, die erforderlich ist, um das Subsystem erfolgreich zu verwenden. Es hilft auch, das Subsystem von potenziell vielen Clients zu entkoppeln. Wenn andererseits die Fassade der einzige Zugangspunkt für ein Subsystem ist, schränkt dies die Leistung und Flexibilität ein, die "fortgeschrittene Benutzer" möglicherweise wünschen.

Das Facade-Objekt sollte ein ziemlich einfacher Vermittler sein. Es sollte kein allwissendes Orakel oder eine „göttliche“ Entität werden.

Struktur

Die Fassade nimmt „ein Rätsel, das in ein geheimnisvolles Rätsel gehüllt ist“ und fügt eine Hülle hinzu, die eine amorphe und unverständliche Masse von Software zähmt, um eine einfache und verständliche Client-Schnittstelle bereitzustellen.

SubsystemOne und SubsystemThree interagieren nicht mit den Interna von SubsystemTwo. Sie verwenden eine SubsystemTwoWrapper-"Fassade" (d. h. eine Abstraktion auf höherer Ebene).

Beispiel

Eine Fassade definiert eine übergeordnete einheitliche Schnittstelle zu einem Subsystem, die die Verwendung erleichtert. Verbraucher stehen vor einer Fassade, wenn sie aus einem Katalog bestellen. Ein Verbraucher ruft eine Nummer an und spricht mit einem Kundendienstmitarbeiter. Der Kundendienstmitarbeiter fungiert als Fassade und stellt eine Schnittstelle zu den Abteilungen Auftragsabwicklung, Rechnungsstellung und Versand bereit.

Kontrollliste

  1. Definieren Sie eine einfachere einheitliche Schnittstelle für ein Subsystem oder eine Komponente.
  2. Erstellen Sie eine „Wrapper“-Klasse, die das Subsystem kapselt.
  3. Fassade/Hülle eliminiert die Komplexität und Interaktion mit der Komponente durch Delegierung der geeigneten Methoden.
  4. Der Bauherr nutzt (befestigt) nur die Fassade.
  5. Überlegen Sie, ob die Fassade zusätzlichen Wert und Funktionalität bringt.

Faustregeln

  • Fassade definiert eine neue Schnittstelle, während Adapter die alte Schnittstelle verwendet. Denken Sie daran, dass ein Adapter zwei vorhandene Schnittstellen unterstützt und keine völlig neue definiert.
  • Während Flyweight zeigt, wie man viele kleine Objekte herstellt, zeigt Facade, wie man ein Objekt herstellt, das ein ganzes Subsystem darstellt.
  • Ein Mediator ähnelt einer Fassade darin, dass er die Funktionalität bestehender Klassen abstrahiert. Der Mediator abstrahiert/zentralisiert willkürliche Beziehungen zwischen Peer-Objekten. Im Gegensatz dazu definiert Facade eine einfachere Schnittstelle für ein Subsystem, fügt keine neue Funktionalität hinzu und ist den Subsystemen nicht bekannt.
  • Abstract Factory kann als Alternative zu Facade verwendet werden, um plattformspezifische Klassen auszublenden.
  • Fassadenobjekte sind oft Singletons, da nur ein Fassadenobjekt benötigt wird.
  • Adapter und Fassade - beide Hüllen; aber sie sind verschiedene Arten von Wrappern. Der Zweck einer Fassade besteht darin, eine einfachere Schnittstelle zu erstellen, und der Zweck eines Adapters besteht darin, eine vorhandene Schnittstelle zu entwickeln. Während eine Fassade normalerweise mehrere Objekte umschließt, umschließt ein Adapter ein einzelnes Objekt; Die Fassade könnte einen Schnittstellenkomplex mit einem einzigen komplexen Objekt haben, und der Adapter könnte mehrere Legacy-Objekte umhüllen.
Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken