• NDK开发,如何配置 debug环境


           刚开始做NDK 开发的时候,Android Studio 还没提供了 native C/C++ 设置断点 调试,我们都是通过输出 日志来调试,这样费时耗力。Android Studio 应该是在 2.2 版本才提供的设置断点 debug 功能,同时在该版本也提供了 cmake 编译。
         我目前在做 NDK 开发的时候,还是习惯用 NDK-Build(也就是设置 Android.mk) 来开发,我先简单说一下怎么用输出日志来调试:
    1、首先在 Android.mk 设置MODULE 添加日志库,如下代码:

    include $(CLEAR_VARS)
    LOCAL_MODULE := ndktest
    LOCAL_SRC_FILES := native_lib.c
    LOCAL_LDLIBS += -llog 
    include $(BUILD_SHARED_LIBRARY)

    2、然后在 native_lib.c 实现文件添加:

    #include <android/log.h>
    
    //为了方便调用,将输出宏定义
    #define LOG_TAG "NATIVE_OUTPUT"
    #define LOGI(...) ((void)__android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__))
    #define LOGE(...) ((void)__android_log_print(ANDROID_LOG_ERROR, LOG_TAG, __VA_ARGS__))

    3、最后就能在 native_lib.c 实现文件的 方法里输出日志了,如:

    LOGI("run here");
    LOGI("run i=%d", i);

    上述是比较繁琐的调试方法,每次写完日志,又要重新编译一下代码。现在叙述一下怎么搭建 native C/C++ 断点调试方法:
    1、首先要把你的 Android Studio 升级到 2.2 或更高,且在Module下 build.gradle 的buildToolsVersion 参数 要 设置 25 或以上: buildToolsVersion '25.0.0'

    2、如果你是新创建项目, 你可以在New Project 时候, 在 Application name 选项下 有个复选框(Include C++ support) 选上,IDE 在构建项目的时候,会帮你配置好了 debug 环境。

    3、如果你是从旧项目移植过来的(也就是以前用 Android.mk配置),你可以打开 Module下 build.gradle文件
    defaultConfig节点中,添加ndk,如下:

    ndk {
         moduleName "imagetool"
         abiFilters "armeabi"//编译支持的平台
         // .. 根据自己的 Application.mk 的配置,按 gradle 规则配置一下
    }

    然后在Android 的节点中,添加 externalNativeBuild 节点:

    externalNativeBuild {
        ndkBuild {
            // Android.mk 的相对路径
             path "src/main/jni/Android.mk"
        }
    }

    接着 sync Project 同步一下项目,你会看见项目多了几个文件夹:


    当你点击 Run Debug 按钮 右边 的Attach debugger to Android process 按钮,如果有 Native、Dual 选择:


    当你点击 Run Debug 按钮 右边 的Attach debugger to Android process 按钮,如果有 Native、Dual 选择:

    说明你配置成功了, 可以在 native-lib.c 实现文件 设置断点来调试了。 上述截图 弹框 是debuger 配置,默认是 auto 选项,你可以设置 成 native 用来debug 你的natvie 代码。

    debug 到 native 的时候如下:

    你可以使用 LLDB 作为你的Debug 辅助工具, LLDB怎么使用,这一章不细说,你可以查阅其它资料。

    参考资料:
    https://developer.android.google.cn/studio/debug/index.html
    https://developer.android.google.cn/index.html (Android 大陆官网)

    tips:假设你已经配置好了NDK开发环境,以及 LLDB 插件。

    在 debug的时候如下出现如下错误:
    Error:FAILURE: Build failed with an exception.

    * What went wrong:
    Execution failed for task ':app:externalNativeBuildDebug'.
    > Build command failed.
    Error while executing process E:AndroidSdk dk-bundle dk-build.cmd with arguments {NDK_PROJECT_PATH=null APP_BUILD_SCRIPT=G:projectAndroidAnti-shake-arithmeticappsrcmainjniAndroid.mk NDK_APPLICATION_MK=G:projectAndroidAnti-shake-arithmeticappsrcmainjniApplication.mk APP_ABI=armeabi NDK_ALL_ABIS=armeabi NDK_DEBUG=1 APP_PLATFORM=android-15 NDK_OUT=G:/project/Android/Anti-shake-arithmetic/app/build/intermediates/ndkBuild/debug/obj NDK_LIBS_OUT=G:projectAndroidAnti-shake-arithmeticappuildintermediates dkBuilddebuglib G:/project/Android/Anti-shake-arithmetic/app/build/intermediates/ndkBuild/debug/obj/local/armeabi/libNDKUtils.so}
    [armeabi] StaticLibrary : libclapack1.a
    process_begin: CreateProcess(NULL, E:/Android/Sdk/ndk-bundle/build//../toolchains/arm-linux-androideabi-4.9/prebuilt/windows-x86_64/bin/arm-linux-androideabi-ar crsD ....

    很有可能是你 defaultConfig节点中,ndk 节点的配置信息与 Application.mk 不匹配,需要你 在ndk 节点添加上去

  • 相关阅读:
    题解 P2280 【[HNOI2003]激光炸弹】
    线段树求逆序对
    题解 P3378 【【模板】堆】
    动态规划-最大算式 蓝桥杯ALGO-116
    动态规划-树形动态规划-结点选择
    Trie树(字典树)-题解 P2580 【于是他错误的点名开始了】
    清北学堂-DAY2-数论专题-中国剩余定理(CRT)
    听课笔记--DP--Authentication Failed
    听课笔记--DP--最大子矩阵和
    多媒体基础
  • 原文地址:https://www.cnblogs.com/xiaoxiaoqingyi/p/7143536.html
Copyright © 2020-2023  润新知