Java execution details in System.out
As I remember there is a magic command line option in Java that turns on writing of operations that are currently executed to the console. The output looks like byte code.
-verbose
does not match as it prints only class loading, while this option outputs information like memory allocation, setting local variables etc. It was very detailed, like 10 lines for "Hello world".
I didn't find it here https://www.oracle.com/ja开发者_JS百科va/technologies/javase/vmoptions-jsp.html or here https://docs.oracle.com/javase/1.5.0/docs/tooldocs/solaris/java.html. Also I have found some flags, but most of them only work in openjdk or in the develop mode. Maybe there is a way I can start java.exe on Windows in this develop mode? Or maybe there is another set of flags that these lists miss?
Not quite what you asked, but I'm a big fan of "kill -3" on the java process id - that dumps out all sorts of information about every thread and what state they are in, what locks they hold and what locks they are waiting on, and that sort of thing.
On windows use Ctrl-Break to create a thread dump.
To monitor classloading use -verbose:class
for garbage collection -verbose:gc
Supported options here. The closest I can find to your description is -verbose:gc, or perhaps -verbose:class.
javap will output bytecode, but it's a static disassembler, and not related to runtime.
I've been using jvisualvm
quite a bit recently; maybe that would give you what you want? It does profiling of both memory and CPU use, can dump thread stacks, and can even persuade the JVM to list what classloader activity is going on (via the MBean support: go to java.lang
→ClassLoading
, select Attributes
and update Verbose
; it still dumps to System.out
of course). The great thing about this is that you don't need to anything to enable it (normally); you can just attach to already running JVMs. (If you've got Java 1.5, use jconsole
instead.)
Note however that you're unlikely to get a dump of what bytecodes are executed. This is because the HotSpot JIT engine – which has been around for a fair few years now – converts the bytecodes to native instructions before execution so by the time the code is actually executed, there's simply no bytecodes left for the instrumentation to report on. Theoretically you might be able to build a special VM that worked in the old way, but it would be horribly slow (like the bad old days) so why would you really want to?
精彩评论