c - 系统小程序 : Assertion failed - any ideas how to debug effectively?

标签 c debugging gdb malloc

我的服务器守护进程在大多数机器上运行良好,但在一台机器上我得到:

malloc.c:3074: sYSMALLOc: Assertion `(old_top == (((mbinptr) (((char *) &((av)->bins[((1)
 - 1) * 2])) - __builtin_offsetof (struct malloc_chunk, fd)))) && old_size == 0) ||
 ((unsigned long) (old_size) >= (unsigned long)((((__builtin_offsetof (struct 
malloc_chunk, fd_nextsize))+((2 * (sizeof(size_t))) - 1)) & ~((2 * (sizeof(size_t))) - 
1)))&& ((old_top)->size & 0x1) && ((unsigned long)old_end & pagemask) == 0)' failed.

gdb 回溯:

#4  0x002a8300 in sYSMALLOc (av=<value optimised out>, bytes=<value optimised out>) at malloc.c:3071
#5  _int_malloc (av=<value optimised out>, bytes=<value optimised out>) at malloc.c:4702
#6  0x002a9898 in *__GI___libc_malloc (bytes=16) at malloc.c:3638
#7  0x0804d575 in xmpp_ctx_new (mem=0x0, log=0x0) at src/ctx.c:383
#8  0x0804916e in main (argc=1, argv=0xbffff834) at ../src/adminbot.c:277

还有什么想法可以尝试吗?我无法在我的代码中找到错误,它可能是 XMPP 库中的错误,我需要确定它。

谢谢。

最佳答案

这几乎可以肯定是由于代码中的堆损坏错误(在分配的 block 之前或之后编写)。

因为您显然是在 Linux 上, 这里要使用的工具是 Valgrind .它应该直接指出问题所在,即使在您的守护程序“工作”的机器上也应该这样做。

尝试除 Valgrind 以外的任何方法来解决此类问题很可能是浪费时间。

关于c - 系统小程序 : Assertion failed - any ideas how to debug effectively?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2317174/

相关文章:

c - C 中的无符号和有符号整数

debugging - Windbg 控制台日志记录

java - 为什么我的解决方案对于反转整数是错误的?

linux - 当我们只有核心文件时如何收集信息/调试

c - 反汇编C,替换操作码

c++ - 共享内存中的队列正在运行

c - x86 汇编中的序言和推送被调用者保存寄存器

c++ - 压缩 PCM 数据

javascript - Chrome 与 JS : Uncaught SyntaxError: Unexpected token )

C - 指向结构组件(指针类型)的指针重新分配已中止(核心转储)