【问题标题】:Dwarf Error: Cannot find DIE矮人错误:找不到 DIE
【发布时间】:2011-06-13 00:28:42
【问题描述】:

我在 XCode 4 的 C++ 项目中调试分段错误时遇到了很多麻烦。

当我使用“LLVM 2.0”编译器选项构建并使用 -O3 优化时,我只会遇到段错误。据我了解,使用优化时调试选项有限,但这是我在打开 gdb 的 Xcode 中运行后得到的调试输出:

warning: Got an error handling event: "Dwarf Error: Cannot find DIE at 0x3be2 referenced from DIE at 0x11d [in module /Users/imran/Library/Developer/Xcode/DerivedData/cgo-hczcifktgscxjigfphieegbpxxsq/Build/Products/Debug/cgo]".
No memory available to program now: unsafe to call malloc

在那之后我无法让 gdb 给我任何有用的信息(比如跟踪),但我不确定我是否真的知道如何正确使用它。当我尝试使用“LLDB”调试器时,Xcode 会崩溃(自从我开始使用它以来,这一直是一个常见的主题)。

我的程序是确定性的,但是当我尝试用打印语句隔离问题时,行为会改变。例如,如果我在某一时刻添加cout << "hello";,那么段错误就会消失。其他打印语句会导致我的程序在其主循环的不同迭代中出现段错误。当然,当我输入足够多的打印语句来确定有问题的代码时,段错误似乎发生在一行之后但在下一行之前(即无处)。

我正在使用指针和动态内存分配,这可能是问题的原因,但由于我无法缩小导致错误的代码块,我不知道在此处显示什么代码。

我尝试使用 Instruments 中的“泄漏”工具进行分析,但没有发现任何泄漏。

有什么建议吗?我对调试非常缺乏经验,所以任何事情都会有所帮助,真的。

编辑:已解决。给定某些输入,我的程序会尝试读取数组末尾的内容。

【问题讨论】:

    标签: c++ macos xcode4 segmentation-fault


    【解决方案1】:

    我认为没有足够的信息可以帮助您解决 DWARF 问题。我对那个工具链不够熟悉,不知道它有多强大。

    但是,您的崩溃症状闻起来很像堆损坏。我不知道 OSX 默认使用什么分配器,但是常见的优化将元数据存储在对象中和/或通过空对象线程化空闲列表,这使得它们对堆上的缓冲区溢出非常敏感。两次释放对象或使用悬空指针(已释放但其空间现在可能被另一个分配使用的指针)也会导致看似不确定且难以跟踪的错误,因为堆的布局可能会在运行。打印语句也使用分配器,这意味着更改打印语句可以改变问题出现的时间和地点。

    我的顾问 (http://prisms.cs.umass.edu/emery/index.php?page=download-diehard) 称为 DieHard 的堆替换工具可以帮助您确定这是堆问题还是无关的问题。我相信它将在 OSX 上构建,您可以使用 LD_PRELOAD=/path/to/libdiehard.so 将其链接到您的程序中,以在运行时替换默认分配器。它的唯一目的是防止内存错误和堆损坏,因此,如果您的应用程序实际使用它运行,那可能就是您需要查看的地方。

    【讨论】:

    • 感谢您提供信息和 DieHard 的链接。我不认为我会释放任何东西两次,但是有很多地方我可以有一个悬空指针。我会尝试更仔细地寻找这种类型的错误。
    猜你喜欢
    • 2012-06-20
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-04-04
    • 2023-03-19
    • 2020-04-28
    • 1970-01-01
    • 2016-05-28
    相关资源
    最近更新 更多