Is there some way to see the native code produces by the JIT in a JVM?
Answer 2: The JVM keeps the JITCed code for each method in C heap, linked to via tables in the internal representation of the class object. The code is only deleted when the JVM ends or in the rare case that the class is "unloaded".
JIT is one of the components of JVM. JVM compiles complete byte code to machine code. JIT compiles only the reusable byte code to machine code.
If you use the OpenJDK JVM, then you can get the source code from here. If you use the Kaffe JVM, you can get the source from here. If you use the Sun JVM version 6 or later, then you can get the source from here. If you use a Sun JVM earlier than 6, then you can often get the source under an academic license.
The JIT compiler is enabled by default, and is activated when a Java method is called. The JIT compiler compiles the bytecode of that method into native machine code, compiling it "just in time" to run. When a method has been compiled, the JVM calls the compiled code of that method directly instead of interpreting it.
As explained by other answers, you can run with the following JVM options:
-XX:+UnlockDiagnosticVMOptions -XX:+PrintAssembly
You can also filter on a specific method with the following syntax:
-XX:+UnlockDiagnosticVMOptions -XX:CompileCommand=print,*MyClass.myMethod
Notes:
If you are running Windows, this page has instructions on how to build and install hsdis-amd64.dll
and hsdis-i386.dll
which are required to make it work. We copy below and extend the content of that page* for reference:
Where to get prebuilt binaries
You can download prebuilt binaries for Windows from the fcml project
How to build hsdis-amd64.dll
and hsdis-i386.dll
on Windows
This version of the guide was prepared on Windows 8.1 64bit using 64-bit Cygwin and producing hsdis-amd64.dll
Install Cygwin. At the Select Packages
screen, add the following packages (by expanding the Devel
category, then clicking once on the Skip
label next to each package name):
make
mingw64-x86_64-gcc-core
(only needed for hsdis-amd64.dll
)mingw64-i686-gcc-core
(only needed for hsdis-i386.dll
)diffutils
(in Utils
category)Run the Cygwin Terminal. This can be done using the Desktop or Start Menu icon created by the installer, and will create your Cygwin home directory (C:\cygwin\home\<username>\
or C:\cygwin64\home\<username>\
by default).
binutils-2.25.tar.bz2
. This should result in a directory named binutils-2.25
(or whatever the latest version is) in your Cygwin home directory.src\share\tools
) to your Cygwin home directory.cd ~/hsdis
.To build hsdis-amd64.dll
, enter
make OS=Linux MINGW=x86_64-w64-mingw32 'AR=$(MINGW)-ar' BINUTILS=~/binutils-2.25
To build hsdis-i386.dll
, enter
make OS=Linux MINGW=i686-w64-mingw32 'AR=$(MINGW)-ar' BINUTILS=~/binutils-2.25
In either case, replace 2.25
with the binutils version you downloaded. OS=Linux
is necessary because, although Cygwin is a Linux-like environment, the hsdis makefile fails to recognize it as such.
./chew: No such file or directory
and gcc: command not found
. Edit <Cygwin home directory>\hsdis\build\Linux-amd64\bfd\Makefile
in a text editor like Wordpad or Notepad++ to change SUBDIRS = doc po
(line 342, if using binutils 2.25) to SUBDIRS = po
. Re-run the previous command.The DLL can now be installed by copying it from hsdis\build\Linux-amd64
or hsdis\build\Linux-i586
to your JRE's bin\server
or bin\client
directory. You can find all such directories on your system by searching for java.dll
.
Bonus tip: if you prefer Intel ASM syntax to AT&T, specify -XX:PrintAssemblyOptions=intel
alongside any other PrintAssembly options you use.
*page license is Creative Commons
Assuming you're using the Sun Hotspot JVM (i.e. the one provided on java.com by Oracle), you can add the flag
-XX:+PrintOptoAssembly
when running your code. This will print out the optimized code generated by the JIT compiler and leaves out the rest.
If you want see the entire bytecode, including the unoptimized parts, add
-XX:CompileThreshold=#
when you're running your code.
You can read more about this command and the functionality of JIT in general here.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With