JNI是Java Native Interface的縮寫,中文為Java本地調用。
JNI是Java標准平台中的一個重要功能,它彌補了JAVA的與平台無關這一重大優點的不足,在Java實現跨平台的同時,也能與其它語言(如C、C++)的動態庫進行交互,給其它語言發揮優勢的機會。
有了Java標准平台的支持,使JNI模式更加易於實現和使用。在此總結了下面這個知識圖:
實例:
環境說明:ubuntu 10.4.2 LTS系統
程序清單1:src/com/magc/jni/HelloWorld.Java
- /**
- *
- */
- package com.magc.jni;
- /**
- * @author magc
- *
- */
- public class HelloWorld {
- static {
- System.loadLibrary("Hello");
- }
- public native void DisplayHello();
- /**
- * @param args
- */
- public static void main(String[] args) {
- new HelloWorld().DisplayHello();
- }
- }
進入src目錄下,編譯該Java類,
命令:javac ./com/magc/jni/HelloWorld.Java
在該HelloWorld.Java所在目錄下生成HelloWorld.class
然後使用Javah生成頭文件,
命令:Javah -jni com.magc.jni.HelloWorld
在當前目錄下生成com_magc_jni_HelloWorld.h頭文件,此文件供C、C++程序來引用並實現其中的函數
程序清單2:com_magc_jni_HelloWorld.h
- /* DO NOT EDIT THIS FILE - it is Machine generated */
- #include <jni.h>
- /* Header for class com_magc_jni_HelloWorld */
- #ifndef _Included_com_magc_jni_HelloWorld
- #define _Included_com_magc_jni_HelloWorld
- #ifdef __cplusplus
- extern "C" {
- #endif
- /*
- * Class: com_magc_jni_HelloWorld
- * Method: DisplayHello
- * Signature: ()V
- */
- JNIEXPORT void JNICALL Java_com_magc_jni_HelloWorld_DisplayHello
- (JNIEnv *, jobject);
- #ifdef __cplusplus
- }
- #endif
- #endif
注:1)、此頭文件是不需要用戶編譯的,直接供其它C、C++程序引用。
2)、此頭文件中的Java_com_magc_jni_HelloWorld_DisplayHello(JNIEnv *, jobject)方法,是將來與動態鏈接庫交互的接口,並需要名字保持一致。
程序清單3:src/jni_helloworldImpl.cpp
- #include<jni.h>
- #include "com_magc_jni_HelloWorld.h"
- #include <stdio.h>
- JNIEXPORT void JNICALL Java_com_magc_jni_HelloWorld_DisplayHello
- (JNIEnv *env, jobject obj)
- {
- printf("From jni_helloworldImpl.cpp :");
- printf("Hello world ! \n");
- return;
- }
此C++文件實現了上述頭文件中的函數,注意方法函數名要保持一致。
編譯生成動態庫libHello.so,
命令:g++ -shared -I /usr/lib/jvm/Java-6-openjdk/include jni_helloworldImpl.cpp -o libHello.so
成功後,便會在當前目錄下生成動態鏈接庫libHello.so文件。
有了具體實現的動態庫後,就可以運行Java調用JNI程序類的native方法了,
命令:java -DJava.library.path=. com.magc.jni.HelloWorld
輸入結果即為:From jni_helloworldImpl.cpp :Hello world !
希望對你有幫助。