当使用 java 命令运行 java 程序时,您可以使用 -verbose 指定详细选项,该选项允许您检查何时加载类。例如:
java -verbose Test | grep "file:"
[Loaded Test from file:/Users... ]
[Loaded C1 from file:/Users... ]
[Loaded A1 from file:/Users... ]
[Loaded B1 from file:/Users...]
[Loaded C2 from file:/Users...]
有没有办法指示验证阶段何时发生?类的验证不一定在加载后直接进行。例如,像这样的东西将是理想的:
java -verbose Test | grep "file:"
[Loaded Test from file:/Users... ]
[Loaded C1 from file:/Users... ]
[Loaded A1 from file:/Users... ]
[Loaded B1 from file:/Users...]
[Verified C1]
[Loaded C2 from file:/Users...]
[Verified C2]
等
为了避免那些"你不需要这个","你为什么要这样做"的答案。它只是出于纯粹的兴趣,仍然值得一提。
正如@Antimony所建议的,要查看何时验证类,需要在重新编译之前修改正在使用的JVM的源代码。
Oracles HotSpot vm 源已经有许多日志记录行来指示不同的验证阶段,并且可以通过更改来启用它们
ClassVerifier::_verify_verbose;
在
/openjdk/hotspot/src/share/vm/classfile/verifier.cpp