在 Eclipse 中,模块路径和类路径有什么区别?

In Eclipse, what is the difference between modulepath and classpath?

在 Eclipse 中,modulepath 和 classpath 有什么区别,我应该使用哪个来在 lib 文件夹中添加 JAR 文件?

为什么 JRE 系统库会出现在模块路径中?

模块系统对代码的影响主要有以下几点:

  • 一个包只能从一个模块访问(嵌套包被视为独立的,所以即使包 java.util 在模块 java.base 中,包 java.util.logging 也可以在模块 java.logging)
  • 您只能访问其他模块的导出包中代码的public 字段和方法。即使使用反射也是如此(即 java.lang.reflect.AccessibleObject.setAccessible(boolean) 仅适用于同一模块中的代码)

类路径上的所有代码都在“未命名”模块中。 模块路径上的所有代码都存在于它们自己的“命名”模块中。

你要区分两种情况:

  • 如果你不添加模块-info.java到你的项目,你的项目将是未命名模块的一部分,并且可以看到未命名模块中的所有其他代码,加上代码在 java.base 中,在 java.se 根模块中的模块中编写代码。基本上这意味着 w.r.t。类路径上的代码,一切仍然像 Java 8 中一样工作,因此您应该将依赖项放在类路径上。

  • 如果您的项目中有模块-info.java,您的项目将位于其自己的命名模块中,并且只能看到 java.base 和其他命名模块中的代码是在模块 info.java 中使用“requires”子句的引用。由于命名模块只能通过模块路径找到,因此您应该将依赖项放在模块路径上。这甚至适用于 Java 9 之前创建的 jar,它将获得从 .jar 文件名派生的模块名称(在这种情况下,它们被称为“自动”模块)。

JRE 始终位于模块路径上,因此即使从类路径上的代码也无法访问其内部代码。

有一种特殊情况:如果你的项目中有一个模块-info.java并且你的项目中有测试代码,你通常不想在[=18]中提到像junit这样的测试依赖。 =].有两种解决方案:

  • 创建专用测试模块。这一直是基于 osgi 的项目的惯例。缺点是你只能在你的测试中使用 public API

  • Maven使用的解决方案:将您的测试依赖项放在类路径中。在编译测试代码时,Maven 添加了命令行选项,允许命名模块中的代码读取未命名模块(这是不可能通过模块-info.java)。

在 Eclipse Oxygen 中,Maven 解决方案是不可能的,因为它不知道哪些代码是测试代码,但这已在即将到来的 Eclipse Photon (4.8) release, which will be out in June. You can already work with the (feature-complete) milestone builds from http://download.eclipse.org/eclipse/downloads/. In case you find any bugs, please report them at https://bugs.eclipse.org/bugs/.

中实现