我的服务器守护进程在大多数机器上运行良好,但在一台机器上我得到:
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/