最近遇到一个 C++程序在退出时,出现内存释放相关的报错,包括以下两种现象:
现象一:
$ ./main
...
free(): invalid pointer
Aborted
现象二:
$ ./main
...
corrupted size vs. prev_size
Aborted
这是一个比较大型的多线程 C++ 项目程序,不太好通过看代码快速定位到问题点。感觉这两种现象是同一个问题导致的,但用 GDB调试了好一会儿,也没有发现导致问题出现的真正原因。无奈之下,想起借助 valgrind也许能发现些什么异常。
最后,还真是 valgrind帮忙定位到了原因,出错的原因是某个模块的一处 memset 调用在某种特殊场景下会出现 7个字节的越界访问,导致破坏了其他模块的内部元数据,进而在程序析构时 C库出现内存释放相关的报错。
下面把用到的 valgrind命令贴出来,大家遇到类似的问题可以尝试用 valgrind来定位:
$ valgrind --leak-check=full --show-leak-kinds=all --track-origins=yes -s your_program

1478

被折叠的 条评论
为什么被折叠?



