调试您的项目

调试原生崩溃

如果您难以理解原生崩溃转储或墓碑,调试原生 Android 平台代码 是一个不错的入门介绍。

有关常见崩溃类型的完整目录以及如何调查这些崩溃,请参阅诊断原生崩溃

ndk-stack工具可以帮助您对崩溃进行符号化。您可以在 Android Studio 中调试崩溃,如通用调试您的应用文档中所述。如果您更喜欢使用命令行,ndk-gdb允许您从 shell 中附加gdblldb

为应用提供对墓碑跟踪的直接访问权限

从 Android 12(API 级别 31)开始,您可以通过ApplicationExitInfo.getTraceInputStream()方法将应用的原生崩溃墓碑作为协议缓冲区进行访问。协议缓冲区使用此模式进行序列化。以前,获取此信息的唯一方法是通过Android Debug Bridge (adb)。

以下是如何在您的应用中实现此功能的示例

ActivityManager activityManager: ActivityManager = getSystemService(Context.ACTIVITY_SERVICE);
MutableList<ApplicationExitInfo> exitReasons = activityManager.getHistoricalProcessExitReasons(/* packageName = */ null, /* pid = */ 0, /* maxNum = */ 5);
for (ApplicationExitInfo aei: exitReasons) {
    if (aei.getReason() == REASON_CRASH_NATIVE) {
        // Get the tombstone input stream.
        InputStream trace = aei.getTraceInputStream();
        // The tombstone parser built with protoc uses the tombstone schema, then parses the trace.
        Tombstone tombstone = Tombstone.parseFrom(trace);
    }
}

调试原生内存问题

Address Sanitizer (HWASan/ASan)

HWAddress Sanitizer (HWASan) 和 Address Sanitizer (ASan) 类似于 Valgrind,但速度明显更快,并且在 Android 上得到更好的支持。

这些是您在 Android 上调试内存错误的最佳选择。

Malloc 调试

请参阅Malloc 调试使用 libc 回调进行原生内存跟踪,以全面了解 C 库内置的调试原生内存问题的选项。

Malloc 钩子

如果您想构建自己的工具,Android 的 libc 还支持拦截程序执行期间发生的所有分配/释放调用。请参阅malloc_hooks 文档以获取使用说明。

Malloc 统计信息

Android 支持mallinfo(3)malloc_info(3)扩展到<malloc.h>

malloc_info功能在 Android 6.0(棉花糖)及更高版本中可用,其 XML 模式在 Bionic 的malloc.h标头中进行了记录。

分析

对于原生代码的 CPU 分析,您可以使用Simpleperf