第一個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,後續持續更新

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