转载请注明出处:

 

       JNI全称是Java Native Interface(Java本地接口)单词首字母的缩写,本地接口就是指用C和C++开发的接口。由于JNI是JVM规范中的一部份,因此可以将我们写的JNI程序在任何实现了JNI规范的Java虚拟机中运行。同时,这个特性使我们可以复用以前用C/C++写的大量代码。

 

       开发JNI程序会受到系统环境的限制,因为用C/C++语言写出来的代码或模块,编译过程当中要依赖当前操作系统环境所提供的一些库函数,并和本地库链接在一起。而且编译后生成的二进制代码只能在本地操作系统环境下运行,因为不同的操作系统环境,有自己的本地库和CPU指令集,而且各个平台对标准C/C++的规范和标准库函数实现方式也有所区别。这就造成使用了JNI接口的JAVA程序,不再像以前那样自由的跨平台。如果要实现跨平台,就必须将本地代码在不同的操作系统平台下编译出相应的动态库。

 

JNI开发流程主要分为以下4步:

1、在eclipse中编写声明了native方法的Java类

2、生成JNI头文件

3、在visual studio 中创建DLL 项目,实现 JNI头文件中的方法

4、在eclipse中设置Native library location,路径为 visual studio 中生成的DLL 文件路径,运行java 程序

 

 

通过上面的介绍,相信大家对JNI及开发流程有了一个整体的认识,下面通过一个HelloWorld的示例,再深入了解JNI开发的各个环节及注意事项。

第一步、在eclipse中新建一个HelloWorld.java

package com.study.jnilearn;  
  
public class HelloWorld {  
      
    public static native String sayHello(String name);  // 1.声明这是一个native函数,由本地代码实现  
  
    public static void main(String[] args) {  
        String text = sayHello("yangxin");  // 3.调用本地函数  
        System.out.println(text);  
    }  
      
    static {  
        System.loadLibrary("HelloWorld");   // 2.加载实现了native函数的动态库,只需要写动态库的名字  
    }  
  
}  

 

第二步、生成JNI头文件

1.配置 javah External tools
   
Windows 下JNI开发流程(visual studio + eclipse) 

如图点击第二项 External tools Configurations


2.配置  如图 


Windows 下JNI开发流程(visual studio + eclipse) 



${project_loc}/src 
-classpath ${project_loc}/bin/classes -d ${project_loc}/jni -jni ${java_type_name} 

 

3. 执行jExternal tools( javah)生成JNI 头文件

第三步、用本地代码实现.h头文件中的函数

Windows 下JNI开发流程(visual studio + eclipse)

Windows 下JNI开发流程(visual studio + eclipse)

Windows 下JNI开发流程(visual studio + eclipse)

将第二步中生成的头文件copy 过来

Windows 下JNI开发流程(visual studio + eclipse)

 

com_study_jnilearn_HelloWorld.h:

/* DO NOT EDIT THIS FILE - it is machine generated */  
#include <jni.h>  
/* Header for class com_study_jnilearn_HelloWorld */  
  
#ifndef _Included_com_study_jnilearn_HelloWorld  
#define _Included_com_study_jnilearn_HelloWorld  
#ifdef __cplusplus  
extern "C" {  
#endif  
/* 
 * Class:     com_study_jnilearn_HelloWorld 
 * Method:    sayHello 
 * Signature: (Ljava/lang/String;)Ljava/lang/String; 
 */  
JNIEXPORT jstring JNICALL Java_com_study_jnilearn_HelloWorld_sayHello  
  (JNIEnv *, jclass, jstring);  
  
#ifdef __cplusplus  
}  
#endif  
#endif  

 

HelloWorld.c:

// HelloWorld.c  
  
#include "com_study_jnilearn_HelloWorld.h"  
  
#ifdef __cplusplus  
extern "C"  
{  
#endif  
  
/* 
 * Class:     com_study_jnilearn_HelloWorld 
 * Method:    sayHello 
 * Signature: (Ljava/lang/String;)Ljava/lang/String; 
 */  
JNIEXPORT jstring JNICALL Java_com_study_jnilearn_HelloWorld_sayHello(  
        JNIEnv *env, jclass cls, jstring j_str)  
{  
    const char *c_str = NULL;  
    char buff[128] = { 0 };  
    c_str = (*env)->GetStringUTFChars(env, j_str, NULL);  
    if (c_str == NULL)  
    {  
        printf("out of memory.\n");  
        return NULL;  
    }  
    (*env)->ReleaseStringUTFChars(env, j_str, c_str);  
    printf("Java Str:%s\n", c_str);  
    sprintf(buff, "hello %s", c_str);  
    return (*env)->NewStringUTF(env, buff);  
}  
  
#ifdef __cplusplus  
}  
#endif  

第六步、运行Java程序

       Java在调用native(本地)方法之前,需要先加载动态库。如果在未加载动态之前就调用native方法,会抛出找不到动态链接库文件的异常。如下所示:

Exception in thread "main" java.lang.UnsatisfiedLinkError: com.study.jnilearn.HelloWorld.sayHello(Ljava/lang/String;)Ljava/lang/String;  
    at com.study.jnilearn.HelloWorld.sayHello(Native Method)  
    at com.study.jnilearn.HelloWorld.main(HelloWorld.java:9)  

设置Native library location

通过ALT + ENTER 调出properties 选项卡

Windows 下JNI开发流程(visual studio + eclipse)

 

费了那么大劲,终于可以运行写好的Java程序了,结果如下:

Java Str:yangxin  
hello yangxin  

 

注意事项:

    java 程序的版本和 dll 程序的版本要对上,例如x64的Java程序 需要编写 x64的dll 动态库

参考: http://blog.csdn.net/xyang81/article/details/41777471

相关文章:

  • 2021-04-13
  • 2021-06-24
  • 2021-09-28
  • 2022-01-08
  • 2021-12-10
猜你喜欢
  • 2022-01-06
  • 2022-01-03
  • 2021-08-29
  • 2021-10-24
  • 2021-08-27
  • 2021-08-23
  • 2021-09-20
相关资源
相似解决方案