java之native

superdont發表於2007-07-05
from:http://blog.csdn.net/huoshen8211/archive/2007/04/19/1570197.aspx

Java不是完美的,Java的不足除了體現在執行速度上要比傳統的C++慢許多之外,Java無法直接訪問到作業系統底層(如系統硬體等),為此Java使用native方法來擴充套件Java程式的功能。
  可以將native方法比作Java程式同C程式的介面,其實現步驟:
  1、在Java中宣告native()方法,然後編譯;
  2、用javah產生一個.h檔案;
  3、寫一個.cpp檔案實現native匯出方法,其中需要包含第二步產生的.h檔案(注意其中又包含了JDK帶的jni.h檔案);
  4、將第三步的.cpp檔案編譯成動態連結庫檔案;
  5、在Java中用System.loadLibrary()方法載入第四步產生的動態連結庫檔案,這個native()方法就可以在Java中被訪問了。

 

JAVA本地方法適用的情況

1.為了使用底層的主機平臺的某個特性,而這個特性不能通過JAVA API訪問

2.為了訪問一個老的系統或者使用一個已有的庫,而這個系統或這個庫不是用JAVA編寫的

3.為了加快程式的效能,而將一段時間敏感的程式碼作為本地方法實現。

 

首先寫好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();
     }
 }
然後根據寫好的檔案編譯成CLASS檔案
然後在classes或bin之類的class根目錄下執行javah -jni com.hode.hodeframework.modelupdate.CheckFile,
 就會在根目錄下得到一個com_hode_hodeframework_modelupdate_CheckFile.h的檔案
然後根據標頭檔案的內容編寫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
最後在執行時加引數-Djava.library.path=[dll存放的路徑]

 

相關文章