Heim >Java >javaLernprogramm >Artikel Bevorzugen Sie Schnittstellen gegenüber Reflexion

Artikel Bevorzugen Sie Schnittstellen gegenüber Reflexion

Barbara Streisand
Barbara StreisandOriginal
2024-10-25 07:51:02702Durchsuche

Reflexion in Java (java.lang.reflect):
Durch Reflexion ist es möglich:

  • Programmgesteuerter Zugriff auf Konstruktoren, Methoden und Felder beliebiger Klassen.
  • Manipulieren Sie Klassen und ihre Mitglieder (Konstruktoren, Methoden, Felder) auf reflektierte Weise, sodass Sie Instanzen erstellen, Methoden aufrufen und auf Felder zugreifen können.
  • Rufen Sie Methoden für Objekte auf, auch wenn die Klassen während der Kompilierung nicht vorhanden sind.

Nachteile der Reflexion:
Verlust der Typprüfung zur Kompilierungszeit:

  • Fehler, die normalerweise beim Kompilieren erkannt würden, treten nur zur Laufzeit auf.
  • Beispiel: Der reflexartige Aufruf einer nicht vorhandenen oder nicht zugänglichen Methode kann zur Laufzeit Ausnahmen generieren.

Schwerer und ausführlicher Code:
Reflexion erfordert komplexeren und weniger lesbaren Code.
Beispiel:

Method method = obj.getClass().getMethod("methodName");
method.invoke(obj, args);

Unterleistung:

  • Der Aufruf einer reflektierenden Methode ist erheblich langsamer als der normale Aufruf.
  • Beispiel: In bestimmten Szenarien kann die Reflektion bis zu 11-mal langsamer sein als der direkte Methodenaufruf.

Anwendungen der Reflexion:

  • Wird in Code-Analysetools, Dependency-Injection-Frameworks und Service-Provider-Frameworks verwendet.
  • Auch in diesen Zusammenhängen sollte es aufgrund seiner Nachteile nach Möglichkeit vermieden werden.

Eingeschränkte Verwendung von Reflexion:
Vorgeschlagene Technik: Verwenden Sie Reflection nur, um unbekannte Klassen zur Kompilierzeit zu instanziieren, und verweisen Sie auf diese Instanzen über bekannte Schnittstellen oder Superklassen.

Beispiel:
Programm, das Instanzen von Set erstellt, die über die Befehlszeile angegeben werden:

Class<? extends Set<String>> cl = (Class<? extends Set<String>>) Class.forName(args[0]);
Constructor<? extends Set<String>> cons = cl.getDeclaredConstructor();
Set<String> s = cons.newInstance();
for (int i = 1; i < args.length; i++) {
    s.add(args[i]);
}
System.out.println(s);

Im Beispiel dargestellte Nachteile:
Laufzeitausnahmen:

  • Das Beispiel kann zur Laufzeit bis zu sechs verschiedene Ausnahmen generieren.
  • Diese Ausnahmen würden zur Kompilierungszeit abgefangen, wenn Reflektion nicht verwendet würde.

Komplexität und Ausführlichkeit:

  • Das Beispiel erfordert 25 Codezeilen, um eine Klasse anhand ihres Namens zu instanziieren, während ein direkter Konstruktoraufruf in nur einer Zeile erfolgen würde.

Unbestätigte Besetzungswarnung:

  • Im Beispiel gibt es eine berechtigte Warnung vor ungeprüfter Umwandlung, da die in der Befehlszeile angegebene Klasse möglicherweise keine Implementierung von Set ist.

Legitime Verwendung von Reflexion:

  • Dynamische Abhängigkeiten: wenn eine Klasse, Methode oder ein Feld zur Laufzeit möglicherweise nicht vorhanden ist.
  • Beispiel: Sie können Reflection verwenden, um mehrere Versionen eines Pakets zu unterstützen, ohne die Abwärtskompatibilität zu beeinträchtigen.

Fazit:
Reflexion ist mächtig, hat aber viele Nachteile.
Verwenden Sie Reflektion nach Möglichkeit nur, um Objekte zu instanziieren und über Schnittstellen oder Superklassen, die zur Kompilierungszeit bekannt sind, auf sie zuzugreifen.

Beispiel aus dem Buch:
Item  Dê preferência às interfaces em vez da reflexão

Das obige ist der detaillierte Inhalt vonArtikel Bevorzugen Sie Schnittstellen gegenüber Reflexion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn