Zum Inhalt springen

Muster: Mediator

Aus Wikibooks

Vermittler

[Bearbeiten]

Ein Vermittler (engl. Mediator) ist ein Software-Design-Pattern und wird in die Gruppe der Verhaltensmuster (Behavioral Patterns) eingeordnet, da es das Ablaufverhalten eines Programmes beeinflussen kann. Das Muster dient zum Steuern des kooperativen Verhaltens von Objekten, wobei Objekte nicht direkt kooperieren, sondern über einen Vermittler. Es stellt einer Reihe von Interfaces eines Subsystems ein vereinheitlichtes Interface zur Verfügung.

Verwendung

[Bearbeiten]

Der Vermittler findet Anwendung, wenn

  • Objekte in einem System auf komplexe Art und Weise kooperieren,
  • die Wiederverwendung von Objekten durch den Bezug auf viele andere Objekte erschwert wird oder
  • Objekte die Objekte, mit denen sie kooperieren nicht kennen können oder sollen.

Vereinheitlicht lässt sich zusammenfassen, dass Programme aus mehreren Klassen bestehen, die die Logik und das Informationsverhalten bestimmen. Vor dem Hintergrund der steigenden Anzahl der Klassen während der Entwicklung und des Refaktorierens ist zu Beachten, dass die Komplexität der Kommunikation zwischen den Klassen steigt. Und genau hier wird die Mediator-Klasse eingesetzt, da nur er detailierte Informationen über Methoden anderer Klassen hat und somit Anfragen von Klassen entgegen nimmt. Nach Annahme von Anfragen andere Klassen entscheidet der Mediator auf Grundlage seines Informationsstandes, welche anderen Klassen zusätzlich "benachrichtigt" werden müssen.

UML-Diagramm

[Bearbeiten]

Datei:W:Vermittler.png

Akteure

[Bearbeiten]
  • Vermittler
    • definiert Schnittstelle zur Kommunikation mit Kollegen
  • KonkreterVermittler
    • implementiert das kooperative Verhalten durch Koordination der beteiligten Kollegen
    • kennt und verwaltet beteiligte Kollegen
  • Kollege
    • kennt seinen Vermittler
    • kommuniziert mit seinem Vermittler statt mit anderen Kollegen

Vorteile

[Bearbeiten]
  • Die Koordination des kooperativen Verhaltens wird zentral verwaltet.
  • Die Veränderung des kooperativen Verhaltens kann unabhängig von den beteiligten Kollegen umgesetzt werden. Solche Änderungen des Verhaltens können durch neue konkrete Vermittler erreicht werden. Dadurch wird die Unterklassenbildung eingeschränkt, da die Änderungen nicht in den verschiedenen konkreten Kollegen vorgenommen und dementsprechend viele neue Unterklassen gebildet werden müssen.
  • Das Muster unterstützt eine lose Kopplung zwischen den Kollegen.
  • Das Protokoll der Kollegen wird vereinfacht.

Nachteile

[Bearbeiten]

Da der Vermittler ein Verhalten kapselt, das andernfalls auf mehrere Klassen verteilt wird, ist er selbst komplexer als die einzelnen Komponenten es gewesen wären. Es besteht die Gefahr, dass ein monolithischer Programmkomplex entsteht, der schwer wart- und erweiterbar ist.

Beispiel

[Bearbeiten]

Ein typisches Beispiel für einen Vermittler ist ein Chatraum. Chatter melden sich beim Chatraum an und ab, um mit anderen Chattern kommunizieren zu können. Sie kommunizieren nicht direkt miteinander, sondern über den Chatraum. Verschiedene konkrete Chaträume können nun unterschiedliche Kommunikationsarten ermöglichen. So kann ein Chatraum Mitteilungen eines Chatters an alle Chatter weiterleiten, ohne dass der Chatter diese kennen muss. Ein anderer Chatraum kann hingegen nur die Kommunikation zwischen einzelnen Chattern ermöglichen. Möchte man die Kommunikation um eine Protokollierung erweitern, erweitert man dazu einen konkreten Chatraum, während die Chatter nicht betroffen sind.

Verwandte Entwurfsmuster

[Bearbeiten]
  • Kollegen können den Vermittler beobachten und umgekehrt.