javac如何自动编译类的依赖关系

给定以下目录结构:

/top

|--- wrk

|--- pkg

|--- A.java

|--- B.java

假设两个文件A.java,并B.java包含下面的代码,分别为:

// Filename: A.java

package pkg;

class A { B b; }

// Filename: B.java

package pkg;

class B {...}

假设当前目录是 /top/wrk

为什么javac -cp . pkg/A.java即使我们尚未编译,命令仍能成功运行B.java

同样,如果当前目录是/top/wrk/pkg该命令,则该命令也javac A.java起作用。为何如此?

回答:

为什么命令javac -cp。即使我们尚未编译B.java,pkg / A.java也会成功运行

当你编译A.java,编译;

B.java以及因为两者A.javaB.java都在同一个包。即使这两个软件包都在目录中并且您从目录进行编译,即使这两个软件包都B.javaA.javaB与公共提供的软件包)不在同一个软件包中,wrk也可以使用。A.java``wrk

从Oracle文档中获得javac

如果未指定-sourcepath选项,则还将在用户类路径中搜索源文件。

从Oracle文档中获取CLASSPATH

类路径的默认值为“。”

如果您尚未设置CLASSPATH,则默认为.。随后,由于默认值与相同,因此sourcepath也将是。您可以使用编译来确认将默认源路径设置为。请注意,编译器正在当前目录中查找文件:.``sourcepath``CLASSPATH``.``A.java``javac

-verbose -g pkg\A.java``.java

[parsing started pkg\A.java] [parsing completed 29ms] [search path for source

files: [.]]

要确认将sourcepath设置为CLASSPATH,可以尝试通过编译使用来更改CLASSPATHusing

-cp选项。由于您已经覆盖了to ,因此这次不会编译,这也是默认设置。这是输出:A.java``javac -cp C:\ -verbose -g

pkg\A.java``A.java``CLASSPATH``C:\``sourcepath

[parsing started pkg\A.java] [parsing completed 26ms] [search path for source

files: [C:\]] pkg\A.java:3: cannot find symbol symbol : class B

同样,如果当前目录为/ top / wrk / pkg,则命令javac A.java也可以使用。为何如此?

不管是否B.class存在pkg

我只能在Windows上确认此行为,但我高度怀疑它在其他操作系统上应该有什么不同。

以上是 javac如何自动编译类的依赖关系 的全部内容, 来源链接: utcz.com/qa/419297.html

回到顶部