转载: java 中 native 的用法 - 不止吧 - 博客园
# 概念:
native 关键字说明其修饰的方法是一个原生态方法,方法对应的实现不是在当前文件,而是在用其他语言(如 C 和 C++)实现的文件中。Java 语言本身不能对操作系统底层进行访问和操作,但是可以通过 JNI 接口调用其他语言来实现对底层的访问。
JNI 是 Java 本机接口(Java Native Interface),是一个本机编程接口,它是 Java 软件开发工具箱(java Software Development Kit,SDK)的一部分。JNI 允许 Java 代码使用以其他语言编写的代码和代码库。Invocation API(JNI 的一部分)可以用来将 Java 虚拟机(JVM)嵌入到本机应用程序中,从而允许程序员从本机代码内部调用 Java 代码。
# native 用法:
- 编写带有 native 声明的方法的 Java 类(java 文件)
2. 使用 javac 命令编译编写的 Java 类(class 文件)
3. 使用 javah -jni **** 来生成后缀名为.h 的头文件(.h 文件)
4. 使用其他语言(C、C++)实现本地方法 (.c/.cpp 文件)
5. 将本地方法编写的文件生成动态链接库(dll 文件)
# 例子:
# 1.java 文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14
| class HelloWorld{
public native void hello(String name);
static{ System.loadLibrary("hello"); }
public static void main(String[] args){ new HelloWorld().hello("JNI"); }
}
|
# 2.javac 命令编译
# 3. 生成 .h 文件
HelloWorld.h 文件内容:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| #include <jni.h>
#ifndef _Included_HelloWorld #define _Included_HelloWorld #ifdef __cplusplus extern "C" { #endif
JNIEXPORT void JNICALL Java_HelloWorld_hello (JNIEnv *, jobject, jstring);
#ifdef __cplusplus } #endif #endif
|
# 4. 实现本地方法
HelloWorld.c
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
| #include <jni.h> #include "HelloWorld.h" #include <stdio.h>
JNIEXPORT void JNICALL Java_HelloWorld_hello(JNIEnv *env,jobject obj, jstring name){ const char *str; str = (*env)->GetStringUTFChars(env, name, NULL); if (str == NULL) { return; } printf("Hello %s!\n", str); return; }
|
# 5. 生成动态链接库(二选一)
1 2 3
| cl -I%java_home%\include -I%java_home%\include\win32 -LD HelloWorldImp.c -Fehello.dll
gcc -m64 -Wl,--add-stdcall-alias -I%java_home%\include -I%java_home%\include\win32 -shared -o hello.dll HelloWorld.c
|
注意:生成的 dll 文件名在选项 - Fe 后面配置,这里是 hello,因为在 HelloWorld.java 文件中我们 loadLibary 的时候使用的名字是 hello。当然这里修改之后那里也需要修改。另外需要将 - I% java_home%\include -I% java_home%\include\win32 参数加上,因为在第四步里面编写本地方法的时候引入了 jni.h 文件。另外在 git 中执行,需要将 % java_home% 替换为 $java_home
# 6. 执行