corrupted size vs. prev_size,解决c++的bug,记录

Posted guomutian911

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了corrupted size vs. prev_size,解决c++的bug,记录相关的知识,希望对你有一定的参考价值。

假定程序执行顺序为A,B,由于A过程的内存越界访问,导致B过程在new内存时出错.(这种bug很隐蔽,是A的问题,却没有反馈出来,直到B才出错,而B本身是没问题的,导致定位错误很费劲)

由于new出来的内存,越界访问不会立即报错,往往是后面才碰到,利用gdb也很难定位错误.

花了一两天时间才定位到问题,之前一直感觉很玄学:

原因:sSA =new long[(N+1)>>offrate +1],应改为:sSA =new long[ ((N+1)>>offrate) +1];

因为,+比>>先执行,我本意是想让N除32然后再加1,但是这里相当于N直接除了64,导致后续访问越界. 例如N为48502,本意是48502/32再加1,应为1516;但这里却是757. 导致后续访问出错.

总结:c++操作内存灵活,但是内存访问很容易会问题,并且调试很麻烦(相比java更好用)

以上是关于corrupted size vs. prev_size,解决c++的bug,记录的主要内容,如果未能解决你的问题,请参考以下文章

VS2010 LINK1123:failure during conversion to COFF:file invalid or corrupt

failure during conversion to COFF:file invalid or corrupt

VS2010报错:LINK : fatal error LNK1123: failure during conversion to COFF: file invalid or corrupt

VS2010报错:LINK : fatal error LNK1123: failure during conversion to COFF: file invalid or corrupt

double free or corruption (out)

Qt5 连接导致 Unhandled Exception 或 HEAP CORRUPTION