如何识别调试器在程序崩溃时显示的调用堆栈可能是错误和误导性的。例如,当调用栈显示以下帧可能丢失或不正确时,这实际上是什么意思?另外,调用堆栈中函数调用后的+数字表示:
kernel32!LoadLibrary + 0x100字节
这个数字对我来说重要吗?如果这个数字很大,那么调用堆栈可能是不正确的吗?
如果我问的是一些琐碎而明显的问题,我很抱歉
谢谢大家
发布于 2009-09-22 13:41:11
一般来说,你可以相信你的callstack是正确的。
但是,如果您显式地重新抛出异常,而不是允许它们自然地在callstack中冒泡,那么实际的错误可能会隐藏在堆栈跟踪中。
发布于 2009-09-22 13:40:24
从第二个开始:kernel32!LoadLibrary + 0x100 bytes意味着调用来自函数LoadLibrary (偏移量:+100字节);显然,没有确切标识调用者的符号信息。这本身并不是调用堆栈被破坏的原因。
如果函数覆盖堆栈上的值(即缓冲区溢出),则调用堆栈可能会损坏。这可能会显示为'0x41445249‘(如果它是我的名字来覆盖它)作为一个调用函数。这超出了您的程序内存范围。
诊断崩溃原因的一种方法是在调用堆栈标识的函数上设置断点。或者使用调试器回溯(取决于调试器和系统)。了解调用中包含哪些参数是一件很有趣的事情。指针通常是一个好的开始(空指针,未初始化的指针)。祝好运。
https://stackoverflow.com/questions/1460139
复制相似问题