Heim >Java >javaLernprogramm >Wie kann ich Warnungen zu „illegalem reflektierendem Zugriff' in Java 9 beheben?

Wie kann ich Warnungen zu „illegalem reflektierendem Zugriff' in Java 9 beheben?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-12-15 03:06:11554Durchsuche

How Can I Resolve

Illegaler reflektierender Zugriff in Java 9: ​​​​Eine detaillierte Untersuchung

Java 9 führte das Konzept des illegalen reflektierenden Zugriffs ein, das zahlreiche weitere auslöste So lösen Sie das Problem. Fragen zu dieser Fehlermeldung. Dieser Artikel befasst sich mit der Natur des illegalen reflektierenden Zugriffs, den Umständen, die Warnungen auslösen, und möglichen Lösungen.

Das Modulsystem in Java 9 führt das Konzept der Modularität #entspannende starke Kapselung ein, das der Schlüssel zum Verständnis des illegalen reflektierenden Zugriffs ist. Der Zugriff von Code in einem Modul auf anderen Modulcode und sichtbare Pakete wird streng kontrolliert. Allerdings kann die starke Kapselung von Modulen gelockert werden, um die Laufzeit von Java 9 zu verlängern.

Das Laufzeitsystem kann die folgenden Operationen bereitstellen:

  • Statischer Zugriff: Wird durch kompilierten Bytecode bereitgestellt.
  • Laufzeitaufrufe: ermöglicht den Aufruf seines Laufzeitsystems mit einem oder mehreren Paketen eines oder mehrerer Module als Code in allen unbenannten Modulen Offen.

Das Konzept des illegalen Zugriffs

Wenn die Reflection-API unter den folgenden Umständen erfolgreich aufgerufen wird, wird ein „illegaler“ Reflection-Zugriff ausgelöst:

  • Normalerweise schlägt der Anruf fehl.
  • „Unerlaubter Zugriff“ ist im Laufzeitsystem aktiviert.

Mechanismus zum Auslösen von Warnungen

Die Lockerung der Kapselung in Java 9 kann zur Kompilierungszeit über die neue Startup-Option --illegal-access gesteuert werden. Standardmäßig ist diese Option auf Zulassen eingestellt. In diesem Modus löst der erste reflektierte Zugriffsvorgang auf ein solches Paket eine Warnung aus, es werden jedoch keine weiteren Warnungen ausgegeben. Diese Warnung enthält Informationen zum Aktivieren weiterer Warnungen.

Konfigurationsoptionen

Die Option --illegal-access kann in den folgenden Modi konfiguriert werden:

  • debug: print für jeden dieser Modi Zugriff auf Nachrichten und Stack-Traces.
  • Warnung: Drucken Sie für jeden solchen Zugriff eine Nachricht aus.
  • verweigern: Diese Art von Vorgang deaktivieren.

Debugging- und Reparaturempfehlungen

  • Führen Sie die Anwendung mit --illegal-access=deny aus, um Moduldeklarationen ohne ( " herauszufinden und zu vermeiden. „Öffnet“ ein Paket von einem Modul zu einem anderen, einschließlich des Öffnens einer solchen Direktive, oder explizit unter Verwendung des VM-Arguments --add-opens.
  • Verwenden Sie das jdeps-Tool mit der Option --jdk-internals, um statische Verweise auf interne JDK-APIs im kompilierten Code zu identifizieren.

Beispiel für eine Warnmeldung

Eine Warnmeldung, die ausgegeben wird, wenn ein illegaler reflektiver Zugriffsvorgang erkannt wird, hat das folgende Format:

WARNING: Illegal reflective access by $PERPETRATOR to $VICTIM

wobei:

  • $PERPETRATOR: der qualifizierte Name des Typs, der den Code enthält, der den Reflexionsvorgang auslöst, und die verfügbare Quelle des Codes (d. h. JAR-Dateipfad).
  • $VICTIM: Eine Zeichenfolge, die das Mitglied beschreibt, auf das zugegriffen wird, einschließlich des qualifizierten Namens des umschließenden Typs.

Vorsichtsmaßnahmen

Um solche Warnungen zu vermeiden und zukünftige Sicherheit zu gewährleisten, müssen Sie sicherstellen, dass Module diese illegalen reflektierenden Zugriffe nicht durchführen.

Das obige ist der detaillierte Inhalt vonWie kann ich Warnungen zu „illegalem reflektierendem Zugriff' in Java 9 beheben?. 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