malloc时出现bus err,分析思路

来源:互联网 发布:sql delete删除语句 编辑:程序博客网 时间:2024/05/17 22:31

最近的某段工作代码malloc时会随机出现bus err,初步怀疑是内存被污染了,但是内存被污染出现bus错误真的还是第一次遇到,惊奇诡异加郁闷。记录个给需要的人参考参考。打开coredump发现进程是因为收到了信号10挂掉,“kill -l” 一看 SIGUSR1! 你妹的SIGUSR1,要不是突然觉得目标机的信号列表可能有差异,老子的青春全给耽误了。最后一番折腾从目标机上简陋的kill命令试出来10号SIG代表SIGBUS。

排插后果然有一段内存污染,堆上的高位内存(超过分配给我的长度)被污染了,怀疑这段高位堆内存跟malloc的链表有关系,这段内存的数据被我htonl了,所以malloc函数内部访问内存时出现BUS错误。

原创粉丝点击