有了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
註:1)、此頭文件是不需要用戶編譯的,直接供其
/* 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
它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 !
[火星人 ] Java基礎之理解JNI原理已經有334次圍觀