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
,可以尝试通过编译使用来更改CLASSPATH
using
-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