JAVA基础之理解JNI原理
2015-07-13 15:22
537 查看
原文地址:http://www.cnblogs.com/mandroid/archive/2011/06/15/2081093.html
JNI是JAVA标准平台中的一个重要功能,它弥补了JAVA的与平台无关这一重大优点的不足,在JAVA实现跨平台的同时,也能与其它语言(如C、C++)的动态库进行交互,给其它语言发挥优势的机会。
有了JAVA标准平台的支持,使JNI模式更加易于实现和使用。在此总结了下面这个知识图:
![](http://pic002.cnblogs.com/images/2011/269610/2011061500160640.png)
实例:
环境说明:ubuntu 10.4.2 LTS系统
程序清单1:src/com/magc/jni/HelloWorld.java
进入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)、此头文件是不需要用户编译的,直接供其它C、C++程序引用。
2)、此头文件中的Java_com_magc_jni_HelloWorld_DisplayHello(JNIEnv *, jobject)方法,是将来与动态链接库交互的接口,并需要名字保持一致。
程序清单3:src/jni_helloworldImpl.cpp
此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 !
本文参考部分内容参考:
1、http://www.iteye.com/topic/304594#814127
2、《Android应用开发详解》
JNI是JAVA标准平台中的一个重要功能,它弥补了JAVA的与平台无关这一重大优点的不足,在JAVA实现跨平台的同时,也能与其它语言(如C、C++)的动态库进行交互,给其它语言发挥优势的机会。
有了JAVA标准平台的支持,使JNI模式更加易于实现和使用。在此总结了下面这个知识图:
![](http://pic002.cnblogs.com/images/2011/269610/2011061500160640.png)
实例:
环境说明:ubuntu 10.4.2 LTS系统
程序清单1:src/com/magc/jni/HelloWorld.java
1 /** 2 * 3 */ 4 package com.magc.jni; 5 6 /** 7 * @author magc 8 * 9 */ 10 public class HelloWorld { 11 12 static { 13 14 System.loadLibrary("Hello"); 15 16 } 17 18 public native void DisplayHello(); 19 /** 20 * @param args 21 */ 22 public static void main(String[] args) { 23 24 new HelloWorld().DisplayHello(); 25 } 26 27 }
进入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 */ 2 #include <jni.h> 3 /* Header for class com_magc_jni_HelloWorld */ 4 5 #ifndef _Included_com_magc_jni_HelloWorld 6 #define _Included_com_magc_jni_HelloWorld 7 #ifdef __cplusplus 8 extern "C" { 9 #endif 10 /* 11 * Class: com_magc_jni_HelloWorld 12 * Method: DisplayHello 13 * Signature: ()V 14 */ 15 JNIEXPORT void JNICALL Java_com_magc_jni_HelloWorld_DisplayHello 16 (JNIEnv *, jobject); 17 18 #ifdef __cplusplus 19 } 20 #endif 21 #endif
注:1)、此头文件是不需要用户编译的,直接供其它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 !
本文参考部分内容参考:
1、http://www.iteye.com/topic/304594#814127
2、《Android应用开发详解》
相关文章推荐
- Eclipse4.4 创建Maven项目
- 关于java.lang.reflect.InvocationTargetException(jar 包缺少或者冲突)的错误
- java中的File.separator
- java java.util.Date、java.sql.Date、java.sql.Time、java.sql.Timestamp区别和联系
- 关于java中的时间
- eclipse导入maven工程pom.xml文件不起作用
- 《Thinking In Java(3rd)》--一切皆对象
- 黑马程序猿——JAVA基础------多重循环语句案例代码
- java I/O
- MyEclipse Java Build Path详解
- 基于Struts2的文件上传
- 记录我的Spring学习过程,大神勿看
- JAVA中的list去重复
- Android eclipse 项目R文件无法生成
- 获取java项目根目录
- 商品添加到购物车模块java程序
- ubuntu中安装jdk
- JAVA多线程和并发性知识点总结
- Java Math.abs
- 关于Java 23种设计模式的有趣见解