一尘不染

在Eclipse中,modulepath和classpath有什么区别?

java

在Eclipse中,modulepath和classpath有什么区别,我应该使用哪一个在lib文件夹中添加jar?为什么JRE系统库出现在modulepath中?


阅读 3939

收藏
2020-09-18

共1个答案

一尘不染

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

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

类路径上的所有代码都一起存在于“未命名”模块中。modulepath上的所有代码都位于其自己的“命名”模块中。

您必须区分两种情况:

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

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

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

有一种特殊情况:如果您的项目中有module-info.java并在项目中有测试代码,则通常不想在中提及诸如junit之类的测试依赖项module- info.java。有两种解决方案:

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

  • maven使用的解决方案:将测试依赖项放在类路径上。在编译测试代码时,maven添加了命令行选项,这些选项允许命名模块中的代码读取未命名模块(无法通过module-info.java实现)。

在Eclipse Oxygen中,不可能使用maven解决方案,因为它不知道哪个代码是测试代码,但这已在即将于六月发布的Eclipse
Photon(4.8)版本中实现。您已经可以使用http://download.eclipse.org/eclipse/downloads/中的(功能完整)里程碑版本进行工作。如果发现任何错误,请通过https://bugs.eclipse.org/bugs/报告。

2020-09-18