首页 >Java >java教程 >Java 9 的非法反射访问:如何识别、触发和解决警告?

Java 9 的非法反射访问:如何识别、触发和解决警告?

Barbara Streisand
Barbara Streisand原创
2024-12-18 17:59:14527浏览

Java 9's Illegal Reflective Access: How to Identify, Trigger, and Resolve Warnings?

了解 Java 9 中的非法反射访问

Java 9 中的非法反射访问是指某些违反模块封装原则的反射操作这个版本。反射访问允许程序动态访问其他类的成员,无论其可见性修饰符如何。

什么定义了非法反射访问?

非法反射访问发生在以下情况:

  • 一个模块尝试访问另一个未明确声明为开放的模块的成员
  • 模块使用反射 API 来调用模块代码无法访问的构造函数、字段或方法。

非法反射访问是如何触发的?

Java 9 运行时监视反射操作。当检测到非法访问时,会发出警告消息。可以通过使用以下模式之一手动指定 --illegal-access JVM 参数来抑制此警告:

  • permit: 对第一次非法访问和静默发出警告后续的。
  • 警告:对每个非法行为发出警告
  • 拒绝:禁用所有非法反射操作。

触发警告的场景

非法当出现以下情况时,会触发反射访问警告遇到:

  • --illegal-access JVM 参数设置为允许或警告。
  • 模块尝试访问另一个对其不开放的模块的成员。
  • 反射访问是通过编译代码的静态引用或通过使用反射来发生的API。

解决非法反射访问

要避免非法反射访问警告,请考虑以下步骤:

  • 确保所有模块都声明其依赖关系并根据需要相互打开包。
  • 使用--add-opens VM 参数以显式打开模块之间的包。
  • 从编译的代码中消除对 JDK 内部 API 的静态引用。
  • 将 --illegal-access JVM 参数设置为拒绝禁用非法反射操作并强制执行强封装。

以上是Java 9 的非法反射访问:如何识别、触发和解决警告?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn