java native方法及JNI實例

前言html

今天在讀java.lang.Object 源碼中時發現一個java

一個hashCode方法:函數

public native int hashCode()

緣由Java很好,使用的人不少、應用極廣,可是Java不是完美的。Java的不足體如今運行速度要比傳統的C++慢上許多以外,還有Java沒法直接訪問到操做系統底層如硬件系統,爲此Java提供了JNI來實現對於底層的訪問。JNI,Java Native Interface,它是Java的SDK一部分,JNI容許Java代碼使用以其餘語言編寫的代碼和代碼庫,本地程序中的函數也能夠調用Java層的函數,即JNI實現了Java和本地代碼間的雙向交互。spa

認識 native 即 JNI,Java Native Interface

   

Native操作系統

JDK開放給用戶的源碼中隨處可見Native方法,被Native關鍵字聲明的方法說明該方法不是以Java語言實現的,而是以本地語言實現的,Java能夠直接拿來用。這裏有一個概念,就是本地語言,本地語言這四個字,我的理解應該就是能夠和操做系統直接交互的語言。.net

Java平臺有個用戶和本地C代碼進行互操做的API,稱爲Java Native Interface (Java本地接口)。xml

用 Java 調用 C 寫的方法

    咱們須要按照下班方便的步驟進行:htm

   一、建立一個Java類,裏面包含着一個 native 的方法和加載庫的方法 loadLibrary。HelloNative.java 代碼以下:blog

public class HelloNative
{
    static
    {
        System.loadLibrary("HelloNative");
    }
     
    public static native void sayHello();
     
    @SuppressWarnings("static-access")
    public static void main(String[] args)
    {
        new HelloNative().sayHello();
    }
}
 

     首先你們注意的是native方法,那個加載庫的到後面也起做用。native 關鍵字告訴編譯器(實際上是JVM)調用的是該方法在外部定義,這裏指的是C。若是你們直接運行這個代碼,  JVM會告之:「A Java Exception has occurred.」控制檯輸出以下:接口

Exception in thread "main" java.lang.UnsatisfiedLinkError: no HelloNative in java.library.path
    at java.lang.ClassLoader.loadLibrary(Unknown Source)
    at java.lang.Runtime.loadLibrary0(Unknown Source)
    at java.lang.System.loadLibrary(Unknown Source)
    at HelloNative.<clinit>(HelloNative.java:5    這是程序使用它的時候,虛擬機說不知道如何找到sayHello。下面既能夠手動寫,天然泥瓦匠是用

    二、運行javah,獲得包含該方法的C聲明頭文件.h

    泥瓦匠將HelloNative.java ,簡單地 javac javah,如圖

 

    就獲得了下面的 HelloNative.h文件 

/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class HelloNative */
 
#ifndef _Included_HelloNative
#define _Included_HelloNative
#ifdef __cplusplus
extern "C" {
#endif
/*
 * Class:     HelloNative
 * Method:    sayHello
 * Signature: ()V
 */
JNIEXPORT void JNICALL Java_HelloNative_sayHello
  (JNIEnv *, jclass);
 
#ifdef __cplusplus
}
#endif
#endif

    jni.h 這個文件,在/%JAVA_HOME%include

    三、根據頭文件,寫C實現本地方法

    這裏咱們簡單地實現這個sayHello方法以下:

#include "HelloNative.h"
#include <stdio.h>
 
JNIEXPORT void JNICALL Java_HelloNative_sayHello
{
    printf("Hello,JNI");   
}

   四、生成dll共享庫,而後Java程序load庫,調用便可。

   在Windows上,MinGW GCC 運行以下

gcc -m64  -Wl,--add-stdcall-alias -I"C:\Program Files\Java\jdk1.7.0_71\include" -I"C:\Program Files\Java\jdk1.7.0_71\include\include\win32" -shared -o HelloNative.dll HelloNative.c
 

   -m64表示生成dll庫是64位的。而後運行 HelloNative:

java HelloNative

   終於成功地能夠看到控制檯打印以下:

Hello,JNI

JNI 調用 C 流程圖

 

轉載地址:http://www.cnblogs.com/Alandre/p/4456719.html

參考地址:http://blog.csdn.net/xw13106209/article/details/6989415

http://www.cnblogs.com/xrq730/p/4824024.html

相關文章
相關標籤/搜索