ndk-stack无法正常工作

时间:2011-11-21 21:04:07

标签: android java-native-interface android-ndk

我按如下方式调用ndk-stack:

cat file_temp | ~/workspace/android-ndk-r6b/ndk-stack -sym /home/xyz/trunk/apk/obj/local/armeabi/

找到崩溃指纹,但无法显示堆栈分析。打印错误是:

ndk-stack: elff/elf_file.cc:102: static ElfFile* ElfFile::Create(const char*): Assertion `read_bytes != -1 && read_bytes == sizeof(header)' failed. Stack frame #00  pc 43121300  Aborted

有什么想法吗?

感谢。

1 个答案:

答案 0 :(得分:1)

这是ndk-stack程序无法读取共享库的未剥离版本。

发生特定崩溃是因为存在与模块名称匹配的文件,但它不够大,无法包含ELF标头。

要做的事情:

  1. 检查通过-sym提供的目录中包含的文件是否正确(而不是截断)。

  2. 删除截断的文件或小于几百字节的文件。

  3. 如果你很好奇,ndk-stack的源代码在ndk/sources/host-tools/ndk-stack

    下的android源代码树中