android開發 NDK相關問題

NDK編譯和使用靜態庫、動態庫

太複雜,見文章:android開發 NDK編譯和使用靜態庫、動態庫


jni頭文件生成:

1. 聲明Java Native接口。(定義Java Native接口可以在Android項目的主類裏聲明,也可以通過使用獨立的類來聲明。)

static { System.loadLibrary("libxxx"); } 

public native void init()

2. 編譯java代碼。

javah -classpath $(BIN_PATH) com.x.y.z.classname

3. 然後即可在當前路徑看到com_x_y_z_classname.h頭文件,實現它就ok。

注意:$(BIN_PATH) 指的是class編譯後bin的位置,對於android開發而言,一般是$project/bin/下面。


在NDK的Nactive代碼中使用Android Log的方法

1.在mk文件加入:

LOCAL_LDLIBS := -L$(SYSROOT)/usr/lib -llog 

2.在cpp文件加入:

#include <android/log.h>

#define LOGI(...) __android_log_print(ANDROID_LOG_DEBUG, "keymatch", __VA_ARGS__) 

3.使用:

LOGI("some log here, %s,%d",__FILE,__LINE__);


分析NDK crash的堆棧信息

1 google提供了一個python腳本,可以從http://code.google.com/p/android-ndk-stacktrace-analyzer/ 下載這個python腳本,然後使用  adb logcat -d > logfile導出 crash 的log, 使用 arm-eabi-objdump 位於build/prebuilt/linux-x86/arm-eabi-4.2.1/bin下面把so或exe轉換成彙編代碼,如:arm-eabi-objdump -S mylib.so > mylib.asm,  使用腳本 python parse_stack.py <asm-file> <logcat-file>

 2 直接使用NDK下面的  arm-eabi-addr2line (推薦)

例如:arm-eabi-addr2line -C -f -e libxxx.so 0x#####  (0x#####是address輸出日誌中最上面的pc值,可以回溯最終函數調用順序)


ndk-gdb 調試方法

1  AndroidManifest.xml <application>包含android:debuggable = "true"

2 執行ndk-build NDK_DEBUG=1 

3 在java代碼調用c之前加一個斷點,然後在gdb命令行加b ***.c:main

   斷點加入方法android.os.Debug.waitForDebugger();

4 執行ndk-gdb

  ndk-gdb --start --force --verbose 顯示更多信息,用於查看步驟中哪裏出錯。


原文:http://hi.baidu.com/joec3/item/05b39524478f863394f62bed

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