初步讲解 JNIEnv 生成的简单的 .h 文件和实现文件

初步讲解 JNIEnv 生成的简单的 .h 文件和实现文件

1.首先利用 javah -d -jni 类的全包名 生成头文件
2.解释生成的 .h 头文件
/* DO NOT EDIT THIS FILE - it is machine generated */
#include "jni.h"
/* Header for class com_slj_ndk_NDKSimple */

// 用来打一个标记,c在编译的时候会把头文件 copy 到你引入的地方,
//不管是重复引用还是相互引用都只会copy一次
#ifndef _Included_com_slj_ndk_NDKSimple
#define _Included_com_slj_ndk_NDKSimple
#ifdef __cplusplus // 相当于 if 语句,如果是c++
// 不管是 c 还是 c++ 统一采用 c 的编译方式,因为在c里面是不允许函数重载的,但是在c++中可以
extern "C" {
#endif
/*
 * Class:     com_slj_ndk_NDKSimple
 * Method:    getSingnaturePassword
 * Signature: ()Ljava/lang/String;
 */
JNIEXPORT jstring JNICALL Java_com_slj_ndk_NDKSimple_getSingnaturePassword
  (JNIEnv *, jobject);

#ifdef __cplusplus
}
#endif
#endif

3.实现 .h 文件
4.解释实现的 .c 文件
//实现我们的native方法
#include "com_slj_ndk_NDKSimple.h"

// JNIEXPORT JNI 的一个关键字,不能少(编译能通过),标记为该方法可以被外部调用
// jstring :代表 java 中的String
// JNICALL :也是一个关键字,可以少 代表是JNI调用
// JNIEnv  :这个是 C 和 java相互调用的桥梁,所有的 function 搞清
// jobject :java传递下来的对象,就是本项目中 JNISimple java对象(普通方法)
// jclass  :java传递下来的 class 对象,就是本项目中的 JNISimple.class(静态方法)
JNIEXPORT jstring JNICALL Java_com_slj_ndk_NDKSimple_getSingnaturePassword
(JNIEnv* env, jobject obj)
{
	return (*env)->NewStringUTF(env,"940223");
}
### 回答1: 在 Java 中执行 .so 文件需要使用 Java Native Interface(JNI)。 首先,需要使用 `javah` 工具生成相应的 C/C++ 头文件,该头文件包含了 Java 代码中调用的 Native 方法的声明。然后,使用 C/C++ 编写对应的本地代码,在该代码中实现 Java 代码中调用的 Native 方法。最后,使用编译器(如 GCC)将本地代码编译成 .so 文件,然后在 Java 代码中使用 `System.loadLibrary` 方法加载 .so 文件即可。 例如,如果要在 Java 代码中调用本地方法 `int add(int a, int b)`,可以这样做: 1. 使用 `javah` 工具生成文件 `Add.h`: ``` javah -jni Add ``` 其中,`Add` 是 Java 代码中包含调用 Native 方法的类的名称。 2. 使用 C/C++ 编写本地代码,在该代码中实现 `add` 方法: ```c++ #include "Add.h" #include <jni.h> JNIEXPORT jint JNICALL Java_Add_add(JNIEnv *env, jclass cls, jint a, jint b) { return a + b; } ``` 3. 使用编译器将本地代码编译成 .so 文件: ``` gcc -shared -fPIC -I/path/to/jdk/include -I/path/to/jdk/include/linux Add.c -o libadd.so ``` 4. 在 Java 代码中使用 `System.loadLibrary` 方法加载 .so 文件: ```java public class Add { static { System.loadLibrary("add"); } public native int add(int a, int b); } ``` 现在 ### 回答2: 在Java中执行.so文件需要借助Java Native Interface(JNI)技术。JNIJava平台提供的一种机制,用于将Java代码与其他语言(如C/C++)的代码进行交互。 为了执行.so文件,我们需要按照以下步骤进行操作: 1. 编写一个Java类,使用JavaJNI库来加载.so文件。可以通过`System.loadLibrary()`方法来加载.so文件。该方法需要指定.so文件的路径或名称。 2. 在Java类中定义与.so文件中的C/C++函数对应的本地方法。使用`native`关键字来声明本地方法方法体为空,只有方法的声明,没有实现。 3. 使用JavaJNI工具生成一个带有本地方法定义的C/C++头文件。可以使用`javah`命令来生成文件,命令格式为:`javah -jni 类名`。 4. 在C/C++文件实现本地方法,编写与Java类中定义的本地方法一一对应的C/C++函数。 5. 编译C/C++文件生成.so文件。在Linux系统上,可以使用GCC编译器来编译C/C++文件生成.so文件。 6. 将生成的.so文件放置在Java类中指定的路径下,或者将.so文件的路径添加到系统的`LD_LIBRARY_PATH`环境变量中,以便Java程序能够正确找到.so文件。 7. 运行Java程序,程序会加载.so文件并执行其中定义的本地方法。 需要注意的是,执行.so文件需要在对应的操作系统中具备对应的.so文件,并且.so文件必须与Java程序所在的操作系统相匹配。 总结:Java通过JNI技术来执行.so文件。需要编写Java类并加载.so文件,定义与.so文件中C/C++函数对应的本地方法生成C/C++头文件实现本地方法生成.so文件,最后在Java程序中调用本地方法执行.so文件中的功能。 ### 回答3: Java是一种高级编程语言,它通过Java虚拟机(JVM)来执行程序。但是,Java本身并不直接支持.so文件的执行。.so文件是Linux和Unix系统中的共享对象文件,在Java中可以通过JNIJava Native Interface)来调用.so文件中的函数。 要执行.so文件,首先需要编写一个JNI接口,将Java中的函数映射到.so文件中的函数。JNI接口使用Javanative关键字来标识一个函数是本地方法,然后在Java代码中调用这个本地方法。在JNI接口中,使用JNI的函数来加载.so文件,并调用其中的函数。 在编译Java代码时,需要使用javac命令生成字节码文件,然后使用javah命令生成JNI文件JNI文件中定义了Java代码需要调用的本地方法。 接下来,需要编写C或C++代码来实现JNI接口,并链接.so文件。在C或C++代码中,使用JNI提供的函数来加载.so文件,并调用其中的函数。最后,使用gcc或g++等工具将C或C++代码编译成可执行文件。 在程序执行时,Java虚拟机加载字节码文件,遇到native关键字的函数时,会通过JNI执行对应的本地方法。在本地方法中,会调用链接的.so文件中的函数。这样,就实现Java调用.so文件的功能。 需要注意的是,执行.so文件需要和操作系统以及架构相匹配,否则可能会出现兼容性问题。此外,编写JNI接口时需要注意函数的参数和返回值的类型匹配,以确保数据能够正确传递。 总而言之,Java通过JNI来执行.so文件,首先需要编写JNI接口并加载.so文件,然后在Java代码中调用本地方法,最终实现Java调用.so文件的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值