5.19. 模块类加载更改
在 JBoss EAP 7 中,当多个模块包含多个类或软件包时,类加载行为已更改。
假设有两个模块 MODULE_A 和 MODULE_B,它们相互依赖,并包含其中一些相同的软件包。在 JBoss EAP 6 中,从依赖项加载的类或软件包优先于 module.xml 文件的 resource-root 中指定的。这意味着 MODULE_A 看到 MODULE_B 和 MODULE_B 的软件包会看到 MODULE_A 的软件包。这个行为令人混淆,可能会导致冲突。JBoss EAP 7 中已更改此行为。现在,module.xml 文件中的 resource-root 指定的类或软件包优先于由依赖项指定的那些。这意味着 MODULE_A 查看 MODULE_A 和 MODULE_B 的软件包是 MODULE_B 的软件包。这可防止冲突,并提供更多适当的行为。
如果您定义了包含资源根库或软件包(其模块依赖项中重复)的 resource-root 库或软件包的自定义模块,您可能会看到 ClassCastException、LinkageError、类加载错误,或者您将迁移到 JBoss EAP 7 时行为的其他更改。要解决这个问题,您必须配置 module.xml 文件,以确保只使用一个类版本。这可以通过以下方法之一来完成。
-
您可以避免指定在模块依赖项中重复类的
resource-root。 您可以使用
importsandexports元素的include和exclude子元素来控制module.xml文件中的类加载。以下是排除类在指定软件包中的导出元素。<exports> <exclude path="com/mycompany/duplicateclassespath/"/> </exports>
<exports> <exclude path="com/mycompany/duplicateclassespath/"/> </exports>Copy to Clipboard Copied! Toggle word wrap Toggle overflow
如果要保留现有行为,则必须使用 filter 元素过滤 module.xml 文件中的依赖 resource-root 中的依赖关系软件包。这样,您可以在 JBoss EAP 6 下保留现有行为。以下是一个 root-resource 示例,它可过滤指定软件包中的类。
<resource-root path="mycompany.jar">
<filter>
<exclude path="com/mycompany/duplicateclassespath"/>
</filter>
</resource-root>
<resource-root path="mycompany.jar">
<filter>
<exclude path="com/mycompany/duplicateclassespath"/>
</filter>
</resource-root>
如需有关模块和类加载的更多信息,请参阅 JBoss EAP 开发指南中的类加载和模块。