javac如何自动编译类的依赖关系
给定以下目录结构:
/top |--- wrk
|--- pkg
|--- A.java
|--- B.java
假设两个文件A.java,并B.java包含下面的代码,分别为:
// Filename: A.javapackage 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.java并B.java都在同一个包。即使这两个软件包都在目录中并且您从目录进行编译,即使这两个软件包都B.java与A.java(B与公共提供的软件包)不在同一个软件包中,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

