Illegal Reflective Access in Java 9: A Detailed Examination
Java 9 introduced the concept of illeir reflective illeich此錯誤訊息的疑問。本文將深入探討非法反射存取的本質,觸發警報的情況以及可能的解決方案。
Java 9 中的模組系統引入了模組化#放鬆強封裝的概念,這是理解非法反射存取的關鍵。模組中程式碼對其他模組程式碼和可見包的存取受到嚴格的控制。然而,為了 облегчить переход на Java 9,模組的強封裝可以被放鬆。
runtime系統可以提供以下操作:
非法存取的概念
如果在以下情況下使用反射API 成功調用,則會觸發「非法」的反射存取:
觸發警報的機制
Java 9 中封裝的放鬆可以透過新的啟動選項 --illegal-access 在編譯時控制。預設情況下,此選項設定為“允許”。在這種模式下,第一次對任何此類套件的反射存取操作將觸發警報,但此後不再發出警告。此警告包含有關如何啟用進一步警告的資訊。
設定選項
--illegal-access 選項可以設定為以下模式:
調試和修復建議
警告訊息範例
非法反射存取操作偵測到時發出的警告訊息遵循以下格式:
WARNING: Illegal reflective access by $PERPETRATOR to $VICTIM
其中:
預防措施
為了避免此類警告並確保將來的安全性,需要確保模組不會進行這些非法反射訪問。
以上是如何解決 Java 9 中的「非法反射存取」警告?的詳細內容。更多資訊請關注PHP中文網其他相關文章!