我在系统库的精彩世界中写了一些东西,我在libc中崩溃,我的库显然传递了错误的值。
有什么方法可以让Android为崩溃的应用程序生成核心转储,以便我可以分解应用程序堆栈?
我特别喜欢,如果有帮助,我会导致system_server崩溃。
编辑:问题的关键在于:当应用程序在像libc这样的库中崩溃时,获取输出的逻辑删除会在libc中显示堆栈跟踪。如果我有一个完整的堆栈跟踪,那么我可以调试整个应用程序。答案 0 :(得分:3)
我假设您正在编写NDK(C / C ++)代码?如果是这样,请检查logcat输出以查找堆栈跟踪。如果您有相应的debug so文件,则可以通过堆栈跟踪工具运行它,例如:http://code.google.com/p/android-ndk-stacktrace-analyzer/wiki/Usage。
logcat跟踪保存在Tombstones中,请参阅此帖子:http://crazydaks.com/debugging-in-android-with-tombstones.html。
对于libc.so中的崩溃,您可以尝试针对这种情况运行arm-eabi-objdump和arm-eabi-addr2line,并比较地址以查看崩溃发生的位置。