如何逐步使用ndk-stack?

Posted

技术标签:

【中文标题】如何逐步使用ndk-stack?【英文标题】:How to use ndk-stack step-by-step? 【发布时间】:2019-06-07 05:04:36 【问题描述】:

我正在尝试调试此错误:

01-12 13:38:18.068 275-275/? I/DEBUG: *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
01-12 13:38:18.068 275-275/? I/DEBUG: Build fingerprint: 'samsung/a53gxx/a53g:5.0.2/LRX22G/A500HXXU1BOJ2:user/release-keys'
01-12 13:38:18.068 275-275/? I/DEBUG: Revision: '10'
01-12 13:38:18.068 275-275/? I/DEBUG: ABI: 'arm'
01-12 13:38:18.068 275-275/? I/DEBUG: pid: 19854, tid: 19854, name: arif.mercuryapp  >>> com.hermessharif.mercuryapp <<<
01-12 13:38:18.068 275-275/? I/DEBUG: signal 11 (SIGSEGV), code 1 (SEGV_MAPERR), fault addr 0x0
01-12 13:38:18.098 275-275/? I/DEBUG:     r0 00000000  r1 00000000  r2 00000001  r3 b6ecbf44
01-12 13:38:18.098 275-275/? I/DEBUG:     r4 b879ebe0  r5 00000000  r6 be9e0c60  r7 00000000
01-12 13:38:18.098 275-275/? I/DEBUG:     r8 00000000  r9 b93ee710  sl 00000000  fp be9e0ce8
01-12 13:38:18.098 275-275/? I/DEBUG:     ip b51084dc  sp be9e0c10  lr b4effde7  pc b6e67204  cpsr 600f0030
01-12 13:38:18.098 275-275/? I/DEBUG: backtrace:
01-12 13:38:18.098 275-275/? I/DEBUG:     #00 pc 00090204  /system/lib/libandroid_runtime.so (GraphicsJNI::getNativeCanvas(_JNIEnv*, _jobject*)+11)
01-12 13:38:18.098 275-275/? I/DEBUG:     #01 pc 00091c31  /system/lib/libandroid_runtime.so
01-12 13:38:18.098 275-275/? I/DEBUG:     #02 pc 00277099  /system/framework/arm/boot.oat
01-12 13:38:19.468 275-275/? I/DEBUG: Tombstone written to: /data/tombstones/tombstone_04

我从this的问题中了解到,我应该使用ndk-stack来获取错误日志的含义。

所以我在 Android Studio 中使用sdk manager 下载了Android NDK,现在我的sdk 目录中有一个ndk-bundle 文件夹。

我已将上述错误日志保存在 error.txt 中,并希望了解它。 根据这个documentation 我想我应该使用-dump 选项。

$NDK/ndk-stack -sym $PROJECT_PATH/obj/local/armeabi-v7a -dump error.txt

文档说:

要使用 ndk-stack,您首先需要一个包含应用共享库的未剥离版本的目录。

仅供参考,我不知道那可能是什么。

如果您使用ndk-build,这些未剥离的共享库位于 $PROJECT_PATH/obj/local/ 中,您的设备的 ABI 在哪里。

但是我没有目录,也不知道怎么制作。

我从未使用过ndk

我试过这个instruction 但没有运气。甚至无法使make 工作。 (讽刺)

你能给我一步一步的指导吗?字面意思是一步一步

TL;DR:

我有上面的错误日志,需要你帮我理解一下。

我对@9​​87654336@ 以及你如何使用它构建一无所知。

感谢您的耐心等待。我知道这个问题可能很愚蠢。

【问题讨论】:

【参考方案1】:

很遗憾,这次崩溃与 NDK 无关,在这种情况下你无法从 ndk-stack 中学到任何东西。

让我解释一下。 ndk-stack 是一种在您自己的本机代码中破译为崩溃日志的工具。在这里,您没有要调试的本机代码。此应用在系统库中崩溃,您无法获取此特定设备的调试信息(这些系统库的未剥离版本)。

如果您知道如何在 Android 模拟器上重现此崩溃,您就有机会进一步调试此原生崩溃。但最有可能的是,这是一个与本机代码无关的错误。也许,您在画布被丢弃后尝试绘制它。

【讨论】:

以上是关于如何逐步使用ndk-stack?的主要内容,如果未能解决你的问题,请参考以下文章

Android NDK- ndk-stack 还原堆栈信息

在 arm64-v8a lib 上运行 ndk-stack 失败并出现错误文件格式无法识别

Android处理native crash(ndk-stack和addr2line)

我的Android进阶之旅如何在Android Studio开发NDK的时候,通过addr2line或者ndk-stack来定位出错代码的位置

制作一个异常的 so 包,并利用 ndk-stack 分析 native 层的 Crash 日志

需要帮助追踪崩溃