This section provides an overview of what jni is, and why a developer might want to use it.
It should also mention any large subjects within jni, and link out to the related topics. Since the Documentation for jni is new, you may need to create initial versions of those related topics.
JNI means Java Native Interface. It is a mechanism how to call a native code from Java application running under JVM control and vice versa. Native code means code compiled for the target platform. Native code code is typically written in C or C++ but it may be written in any language that has compiler for the target platform.
JNI is useful when
To start with JNI you need
The following hello world example is a simple java application that calls a C function. The example can be compiled by javac from JDK and gcc C compiler.
Java code:
public class JNIExample {
public static void main(String[] args) {
// The loadLibrary search for the native library (libnative.so in this case)
System.loadLibrary("native");
String s = "Hello JNI";
JNIExample example = new JNIExample();
example.doPrint(s);
}
// The method with native code (written in C) must be declared with native prefix
public native void doPrint(String message);
}
C code:
#include <jni.h>
#include <stdio.h>
/* the function that is called from java must be declered with decorators
* JNIEXPORT and JNICALL.
* The function name is constructed as Java_ClassName_MethodName
* Function parameters correspond parameters in java but there are 2 extra parameters
* JNIEnv is a pointer to java envoronmet and jobject is a reference to caller object.
* Caller object is the instance of the JNIExample in this case.
*/
JNIEXPORT void JNICALL Java_JNIExample_doPrint(JNIEnv *e, jobject obj, jstring message) {
const char *c_message;
/* It is necessary to convert java objects like string to something C native */
c_message = (*e)->GetStringUTFChars(e, message, NULL);
printf("%s\n", c_message);
/* in the end it is necessary to free resources allocated by Get above */
(*e)->ReleaseStringUTFChars(e, message, c_message);
}