为什么命令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 pkgA.java``.java
[parsing started pkgA.java] [parsing completed 29ms] [search path for sourcefiles: [.]]
要确认将
sourcepath设置为
CLASSPATH,可以尝试通过编译使用来更改
CLASSPATHusing
-cp选项。由于您已经覆盖了to ,因此这次不会编译,这也是默认设置。这是输出:
A.java``javac -cp C: -verbose -gpkgA.java``A.java``CLASSPATH``C:``sourcepath
[parsing started pkgA.java] [parsing completed 26ms] [search path for sourcefiles: [C:]] pkgA.java:3: cannot find symbol symbol : class B
同样,如果当前目录为/ top / wrk / pkg,则命令javac A.java也可以使用。为何如此?
不管是否
B.class存在
pkg
免责声明: 我只能在Windows上确认此行为,但我高度怀疑它在其他 *** 作系统上应该有什么不同。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)