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

时间:2018-05-13 23:44:17

标签: java eclipse classpath module-path

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

1 个答案:

答案 0 :(得分:11)

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

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

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

你必须区分两种情况:

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

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

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

有一个特例:如果项目中有module-info.java并且项目中有测试代码,那么通常不希望在module-info.java中提到像junit这样的测试依赖项。有两种解决方案:

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

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

在Eclipse Oxygen中,maven解决方案是不可能的,因为它没有任何代码是测试代码的概念,但是这已经在即将发布的Eclipse Photon(4.8)版本中实现,该版本将在6月发布。您已经可以使用http://download.eclipse.org/eclipse/downloads/中的(功能完整的)里程碑版本。如果您发现任何错误,请在https://bugs.eclipse.org/bugs/报告。