第一个jni实例及简单查看报错

写关于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文件的路径
ndk-stack

通过addline 查看报错日志:
在这里插入图片描述
以上是一个小小的demo,后续持续更新

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章