JAVA JNI原理詳細引見及復雜實例代碼。本站提示廣大學習愛好者:(JAVA JNI原理詳細引見及復雜實例代碼)文章只能為提供參考,不一定能成為您想要的結果。以下是JAVA JNI原理詳細引見及復雜實例代碼正文
JAVA JNI原理
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 !
感激閱讀,希望能協助到大家,謝謝大家對本站的支持!