- Markierungsschnittstelle
-
Eine Markierungsschnittstelle (englisch Marker Interface oder Tag Interface[1]) ist ein Entwurfsmuster, das dem Programm zur Laufzeit Informationen über ein Objekt liefert. Dies bietet die Möglichkeit einer Klasse Metadaten hinzuzufügen, obwohl die Programmiersprache dies nicht explizit unterstützt.
In diesem Muster implementiert eine Klasse eine Schnittstelle welche meistens keine Funktionalität in der Form von Methodendeklarationen definiert. Andere (klassenfremde) Methoden testen bei einer Interaktion mit der Klasse, ob die Markierungsschnittstelle für die (instanzierte) Klasse existiert. Die Anwesenheit einer solchen Schnittstelle definiert ein bestimmtes Verhalten für die implementierende Klasse. Hybridschnittstellen welche sowohl als Markierung fungieren, als auch Methoden deklarieren sind grundsätzlich möglich, aber können bei falscher Verwendung verwirrend sein.
Ein Beispiel für die Verwendung von Markierungsinterfaces in der Programmiersprache Java ist die
Serializable
-Schnittstelle, welche signalisiert, dass die persistenten Attribute der implementierende Klasse in einenObjectOutputStream
geschrieben werden können. Die MethodeObjectOutputStream.writeObject()
enthält einigeinstanceof
-Tests, welche prüfen, ob das übergebene Objekt die SchnittstelleSerializable
enthält. Falls dies nicht der Fall ist, wird eineNotSerializableException
geworfen.Kritik
- "Schweres Erbe"
- In der Objektorientierten Programmierung wird die Implementierung auch der schmalsten Schnittstelle an erbende Klassen weitergegeben. Dies bedeutet, dass eine Klasse, die von einer serialisierbaren Klasse erbt, nicht als „nicht serialisierbar“ definiert werden kann. Deshalb wird teils auf die Laufzeit ausgewichen, um logische Fehler überhaupt offenzulegen: In der Java-Dokumentation wird so beispielsweise empfohlen, explizit eine
NotSerializableException
zu werfen.
- "Smell"
- Ein anderes Problem ist die Tatsache, dass zum Erkennen einer Markierungsschnittstelle der Operator instanceof („Instanz von“) verwendet werden muss, was als Smell („schlechter Geruch“, d. h. fragwürdige Programmiertechnik) betrachtet werden kann und somit auch das Muster als Smell charakterisiert.[1]
- Verschleierung
- Die Programm-Logik wird aus dem regulären Quelltext in Frameworks verlagert, die auf der Analyse von Metadaten aufbauen. Das macht sie für Menschen schwer nachvollziehbar. Markierungsschnittstellen selbst zu definieren, ist für alltägliche Programmieraufgaben meist völlig überzogen. Da jedoch das Markieren ("Tagging") als Technik vertraut erscheint, neigen OO-Anfänger leicht zu diesem Mittel (um die Aufgabe letztlich nur aufzuschieben). Durch den Einsatz von Markierungsschnittstellen entzieht man dem Compiler Möglichkeiten zur statischen Prüfung.
Literatur
- Christian Ullenboom: Java ist auch eine Insel. Das umfassende Handbuch. 10 Auflage. Galileo Computing, Galileo Press, 28. Oktober 2011, ISBN 978-3-8362-1802-3, 5.3.13 Markierungsschnittstellen.
Einzelnachweise
- ↑ a b Marker Interface. In: Portland Pattern Repository. Ward Cunningham, 9. Juli 2002, abgerufen am 19. Februar 2009 (englisch).
Wikimedia Foundation.