写关于jni方面的文章,仅仅只是为了做个记录而已,因为自己对于jni方面的知识很少有接触,所以都比较浅,只是闲来,学习记录一下!
java调用jni方法,获取返回值
第一步:在java中声明native方法
如下:
public static native String getJniData();
第二步:生成 声明了native方法的头文件
在as工具Terminal下 输入命令 注意输入的路径
F:\asProject\app\src\main\java>javah -d …/jni com.example.a13940.myapplication.MyFirstJni
第三步:新建一个.cpp和.h文件 ,并在cpp文件中引用生成的头文件 和重新写入生成的native方法,如下图1和图2
First.cpp文件内容
特别注意:#include里面文件路径的书写
#include "com_example_a13940_myapplication_MyFirstJni.h"
JNIEXPORT jstring JNICALL Java_com_example_a13940_myapplication_MyFirstJni_getJniData
(JNIEnv * env, jclass jcls){
return env->NewStringUTF("FORM C DATA");
}
第四步:生成so文件和引用so库
在build.gradle文件中配置生成so库的名称和平台信息
在MyFirstJni中配置加载so库
public class MyFirstJni {
//加载so库
static {
System.loadLibrary("firstC");
}
//定义navie方法
public static native String getJniData();
}
第五步:最后获取jni层返回的数据
String data = MyFirstJni.getJniData();
则data = “FROM C DATA”;
最后说明一下,生成的so文件的路径为:当前项目下的
\app\build\intermediates\ndk\debug\obj\local
知道了写简单的jni 就要知道怎么查看简单的报错
查看log日志 adb logcat
通过ndk-stack 查看报错日志:
完整命令如下:
adb logcat | ndk-stack -sym so文件的路径
通过addline 查看报错日志:
以上是一个小小的demo,后续持续更新