Java不是完美的,Java的不足除了體現(xiàn)在運行速度上要比傳統(tǒng)的C++慢許多之外,Java無法直接訪問到操作系統(tǒng)底層(如系統(tǒng)硬件等),為此Java使用native方法來擴展Java程序的功能。
可以將native方法比作Java程序同C程序的接口,其實現(xiàn)步驟:
1、在Java中聲明native()方法,然后編譯;
2、用javah產(chǎn)生一個.h文件;
3、寫一個.cpp文件實現(xiàn)native導出方法,其中需要包含第二步產(chǎn)生的.h文件(注意其中又包含了JDK帶的jni.h文件);
4、將第三步的.cpp文件編譯成動態(tài)鏈接庫文件;
5、在Java中用System.loadLibrary()方法加載第四步產(chǎn)生的動態(tài)鏈接庫文件,這個native()方法就可以在Java中被訪問了。
JAVA本地方法適用的情況
1.為了使用底層的主機平臺的某個特性,而這個特性不能通過JAVA API訪問
2.為了訪問一個老的系統(tǒng)或者使用一個已有的庫,而這個系統(tǒng)或這個庫不是用JAVA編寫的
3.為了加快程序的性能,而將一段時間敏感的代碼作為本地方法實現(xiàn)。
首先寫好JAVA文件
/*
* Created on 2005-12-19 Author shaoqi
*/
package com.hode.hodeframework.modelupdate;
public class CheckFile
{
public native void displayHelloWorld();
static
{
System.loadLibrary("test");
}
public static void main(String[] args) {
new CheckFile().displayHelloWorld();
}
}
然后根據(jù)寫好的文件編譯成CLASS文件
然后在classes或bin之類的class根目錄下執(zhí)行javah -jni com.hode.hodeframework.modelupdate.CheckFile,
就會在根目錄下得到一個com_hode_hodeframework_modelupdate_CheckFile.h的文件
然后根據(jù)頭文件的內容編寫com_hode_hodeframework_modelupdate_CheckFile.c文件
#include "CheckFile.h"
#include
#include
JNIEXPORT void JNICALL Java_com_hode_hodeframework_modelupdate_CheckFile_displayHelloWorld(JNIEnv *env, jobject obj)
{
printf("Hello world!"n");
return;
}
之后編譯生成DLL文件如“test.dll”,名稱與System.loadLibrary("test")中的名稱一致
vc的編譯方法:cl -I%java_home%"include -I%java_home%"include"win32 -LD com_hode_hodeframework_modelupdate_CheckFile.c -Fetest.dll
最后在運行時加參數(shù)-Djava.library.path=[dll存放的路徑]