Boehm GC:如何有效地调试崩溃的堆对象?
运行我的程序时,我从Boehm GC(定义了GC_调试)中得到以下错误:Boehm GC:如何有效地调试崩溃的堆对象?,c,garbage-collection,valgrind,boehm-gc,C,Garbage Collection,Valgrind,Boehm Gc,运行我的程序时,我从Boehm GC(定义了GC_调试)中得到以下错误: GC\u检查\u堆块:找到破碎的堆对象: 0x8ef1008位于0x8ef1010处的对象内部或附近(,近似值sz=29) 0x8ef1188位于0x8ef1190处的对象内部或附近(,近似值sz=29) ... 上述情况持续了大约20次 奇怪的是,我没有发现这个程序有什么问题,它做了它应该做的,并且没有崩溃 我可以编译禁用GC的程序。然后我可以用它运行valgrind,但奇怪的是,valgrind没有发现任何问题 这可
GC\u检查\u堆块:找到破碎的堆对象:
0x8ef1008位于0x8ef1010处的对象内部或附近(,近似值sz=29)
0x8ef1188位于0x8ef1190处的对象内部或附近(,近似值sz=29)
...
上述情况持续了大约20次
奇怪的是,我没有发现这个程序有什么问题,它做了它应该做的,并且没有崩溃
我可以编译禁用GC的程序。然后我可以用它运行valgrind,但奇怪的是,valgrind没有发现任何问题
这可能是Boehm GC中的一个问题——我应该忽略它吗
有人知道如何有效地调试它吗
或者,有人能解释一下上述信息的确切含义吗?三个多月后回答我自己的问题 我尝试将每个指针记录到一个文件中,并与发出警告的指针进行比较。然而,这并没有导致任何结果,可疑的指针来自整个代码库的各种分配(没有一个特定的地方可能被破坏) 同时,没有GC,valgrind没有报告任何错误,但当然这并不意味着不可能仍然存在错误 然而,我想如果这个特定版本的GC有一个微妙的bug,我会试试。我使用的是最新的稳定版本gc7.1。我升级到7.2alpha4,问题就消失了 如果有人遇到这个问题,希望这会有所帮助
GC_check_heap_block: found smashed heap objects:
0x8ef1008 in or near object at 0x8ef1010(<smashed>, appr. sz = 29)
0x8ef1188 in or near object at 0x8ef1190(<smashed>, appr. sz = 29)
...