gpt4 book ai didi

java - 使用 java serviceloader build with jdk 8 在 >= java 9 中使用

转载 作者:行者123 更新时间:2023-12-05 02:08:25 24 4
gpt4 key购买 nike

我有两个 jar 。一种提供服务接口(interface)和服务加载类,一种提供该服务的实现。

这在 jdk8 中运行时完美运行,但在 jdk9 或更高版本上运行时出现 service type not accessible to unnamed module @3754a4bf 错误。

我将这两个 jar 迁移到一个模块基础 jar,并且在 >= jdk9 上运行时效果很好,但由于错误的类文件版本,在 jdk8 上失败了。

所以,我在 java 8 或 9 中使用 java serivceloader api 没有问题。

我知道 https://blog.codefx.org/tools/multi-release-jars-multiple-java-versions/ ,但我想避免使构建过程更加复杂。构建已经涉及类重定位和其他东西。

我的问题:有没有办法使用 java serviceloading api 在 jdk8 和 >=jdk9 上运行相同的 jar?

最佳答案

在 JDK9 及更高版本中,所有 jar 都是有效的“模块”。如果它们没有有一个模块定义(你通过创建一个名为 module-info.java 的文件并在其中放置一个模块声明来创建),它的名字是“未命名模块” @whatever',它导出所有包,并且可以访问任何其他模块导出的任何内容(在模块中:它“读取”所有内容)。意思是,如果 所有 你的类路径依赖项都是这样的未命名模块,它们都导出所有内容并且它们都读取所有内容因此它们都可以从任何其他人访问任何标记为 public 的内容 - 这就是如何它在 JDK8 中工作,因此,为什么它都是兼容的。

明确一点:在 JDK9 中,模块 (jar) A 中的代码要访问模块 (jar) B 中的方法、类或字段,那么除了通常的访问修饰符(public 关键字),B 需要“导出”那个包,而 A 需要读取那个模块,否则它不起作用。如果您没有明确地为任何一方编写模块信息文件,那么您将获得默认行为,即“导出所有内容”和“读取所有内容”,将我们带回 JDK8 场景:必须将事物标记为 public,然后就可以访问了。

我实际上不建议你制作那个模块信息文件;这是一大步,您只有在熟悉模块系统后才应该迈出这一步。

该错误意味着“服务类型”[1] 对“未命名模块 @3754a4bf”[3] 不可“访问”[2]。让我们把它分成几个部分:

[1] serviceloader 通过定义一个“服务提供者”实现的接口(interface)来工作,然后使用服务加载器的类以该接口(interface)的一堆实例结束;每个代表一个实现。它是 ServiceLoader.load(Foo.class) 中的 Foo

[2]“可访问”是模块的代名词:需要它的代码没有明确地“读取”它,或者拥有它的代码没有导出它。

[3] 'unnamed module@3754abf' 是试图访问它的模块的名称。

综上所述,这意味着:您在错误的假设下运行:无论 jar 包含您的服务接口(interface)(我正在谈论的那个 Foo),都不是一个未命名的模块,或者可能不是公开的。请注意,如果它是非公共(public)类中的公共(public)接口(interface)(即:/* package private */class Example { public interface MyServiceInterface {} } ),那可能仍然算作“不够公开” '.

如果是命名模块(意思是:它有一个module-info.java文件),那么导出服务接口(interface)所在的包。看任意拼图(java的名字)模块系统)关于如何设置它的教程。如果不是,请确保它是公共(public)接口(interface)或抽象类,如果它在其他类型中,请确保它们也是公共(public)的。如果两者都不是,请检查您的类路径; javac 相当坚持这两种情况之一。

关于java - 使用 java serviceloader build with jdk 8 在 >= java 9 中使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60930160/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com