What are the usual steps that the JVM runtime has to perform when calling a Java method that is declared as native
?
How does a HotSpot 1.8.0 JVM implem
Calling a JNI method from Java is rather expensive comparing to a simple C function call. HotSpot typically performs most of the following steps to invoke a JNI method:
JNIEnv*
and jclass
for static methods and pass them as additional arguments.method_entry
trace function.synchronized
.in_java
to in_native
state.in_java
state.method_exit
.The source code for this procedure can be found at SharedRuntime::generate_native_wrapper.
As you can see, an overhead may be significant. But in many cases most of the above steps are not necessary. For example, if a native method just performs some encoding/decoding on a byte array and does not throw any exceptions nor it calls other JNI functions. For these cases HotSpot has a non-standard (and not known) convention called Critical Natives
, discussed here.