我在系统库的精彩世界中写了一些东西,我在libc中崩溃,我的库显然传递了错误的值。
有什么方法可以让Android为崩溃的应用程序生成核心转储,这样我就可以分解应用程序堆栈了吗?
我特别是,如果有帮助,我会导致system_server崩溃。
编辑:我的问题的要点是:当应用程序在像libc这样的库中崩溃时,获取输出的逻辑删除显示libc中的堆栈跟踪。如果我有一个完整的堆栈跟踪,那么我可以调试整个应用程序。
我假设您正在编写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,并比较地址以查看崩溃发生的位置。