Instanceof außerhalb der equals-Methode

Aus Programmieren-Wiki
🚧 Diese Seite befindet sich in Bearbeitung 🚧
🤓 Diese Seite ist eine Bewertungsrichtlinie, die ab Blatt 1 annotiert und ab Blatt 2 abgezogen wird. 🤓

Beschreibung

Die Java API bietet uns das Schlüsselwort instanceof, um zu prüfen, ob eine Objekt eine Instanz einer bestimmten Schnittstelle (Interface) oder Klasse ist.

In aller Regel kann die Verwendung von instanceof durch den Einsatz von Polymorphie umgangen werden, das heißt, man definiert eine Methode in der Oberklasse/im Interface, von dem alle betroffenen Klassen erben, die das gewünschte Verhalten umsetzt. Die Verwendung von instanceof gilt daher als äußerst schlechter Stil.

Im Rahmen dieses Übungsbetriebs ist die Verwendung von instanceof somit unzulässig.

Eine einzige Ausnahme besteht in der Implementierung der equals(Object o)-Methode einer Klasse. Üblicherweise prüft man in eigenen Implementierungen von equals zuallererst, ob das "andere" Objekt null ist, und wenn nicht, ob eine Instanz der entsprechenden Klasse ist. Diese beiden Prüfungen sind in einer instanceof-Abfrage möglich, wie im Positivbeispiel beschrieben. Zu diesem Zweck ist der Einsatz von instanceof erlaubt.


Negativbeispiel

public void talk(Person[] persons) {
	for (Person person : persons) {
		if (person instanceof InfoStudent) {
			System.out.println("Ich studiere Informatik …");
		} else if (person instanceOf Employee) {
			System.out.println("Ich arbeite in der Industrie …");
		}
	}
}

Hier bestimmen instanceOf-Abfragen das gewünschte Verhalten. Eine viel bessere Lösung wäre es hier, in der Klasse Person eine abstrakte Methode zu definieren, die einen String zurück- oder ausgibt. Diese Methode sollte dann von der Employee und InfoStudent Klasse geerbt und implementiert werden.

Positivbeispiel

class Book {
	[...]
	@Override
	public boolean equals(Object obj) {
		// This will also do an implicit null-check so we don't have to worry about that here
		return (obj instanceof this);
	}
}