• android 开发 ndk相关问题


     

    index: 

    NDK 编译和使用静态库、动态库

    jni头文件生成

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

    分析NDK crash的堆栈信息

     ndk-gdb 调试方法

    NDK 编译和使用静态库、动态库

    太复杂,见新文章:http://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 显示更多信息,用于查看步骤中哪里出错

  • 相关阅读:
    命令行下的curl使用详解
    升级python版本(从2.4.3到2.6.5)
    vim设置
    php中curl模拟post提交多维数组
    vim折叠设置
    基础算法4——归并排序
    总线类型
    主板分类
    网卡 接口类型
    基础算法3——直接选择排序和堆排序
  • 原文地址:https://www.cnblogs.com/echo6106/p/3068542.html
Copyright © 2020-2023  润新知