背景
最近这刁钻的问题都让我碰上了,产品运行一到两天后就不正常工作了。输出各个过程的信息发现有块内存的内容不正常,本该是一些固定的数据,发现跟程序设定的不一样了,最后仿真发现提示outof heap,堆超限了。。。,也不是每次都提示堆超限吧,多少次后会提示堆超限呢?
问题分析
看到内存在没有使用的情况下里面的内容都是0
产品跟外界产品一直在通信,每次接收到符合协议的内容都会申请(malloc)1024Byte的内存,但是却只释放(free)了收到字节个数的大小,次数足够多后就会覆盖别的内容,导致程序得不到想要的结果,时间再长些之后应该会导致申请不到内存,造成内存泄露,导致程序运行卡顿,与看到有时候卡顿现象相符。
申请不到内存时就会返回一个空指针。这样的话程序也应该不能正常运行了。程序尝试操作一个空指针会导致程序崩掉。