2、2018-1-12. C/C++程序稳健性的关键之一,内存泄露。当科研成果要顺利的用于产业界时,必须要经受住长时间运行程序和算法高频次调用的考验。自身编写的程序造成会内存泄露的原因主要有以下几点:
a、malloc/calloc和free对应, new/new type [] 和delete/delete[]对应。使用内存的时候,切记何时释放。
b、程序架构庞大,模块众多时,接口设计和使用说明必须明确。以免造成函数内部申请的内存,调用函数后,却未在外部释放。
c、对于结构体指针的内存申请和释放,建议编写特定对应申请和释放函数,以免和free/delete混淆,同时也便于及时检测发现错误,起到一定的规范性。
1、2017-3-26. 从昨天晚上到今天中午,竟然出现了申请内存都会出现错误。Critical error detected c0000374 (错误1)和Free Heap block XXXXXX modified at XXXXXX after it was freed(错误2)和Unhandled exception,Heap corruption(错误3)的错误。经过再三的调试和检测,整个工程的逻辑和算法没有错误,于是非常纠结。
在C/C++中malloc/calloc和free相匹配,new和delete(delete[])相匹配。通常,内存泄漏的本质原因都是申请了内存而未手动释放,动态分配的内存如果没有释放,则该内存区域会一直占用直到整个程序结束,在实际大型工程中,是不允许存在的,否则处理器运行不久就会越来越卡,只能重启。
出现错误1-3,都会导致堆内存块损坏。经过仔细排查,终于找到症结所在。需要注意以下几点:
a、对于错误2,错误3. 可能的原因是由于申请时就出现了问题,或者申请和释放的内存不是同一区域导致,在申请内存时要一定保证类型相同。
struct point2i{
int x,y;
};
//错误point2i -->int,这种做法极其容易导致程序出现访问错误
int * buffer_temp = (int*)calloc(length,sizeof(point2i));
free(buffer_temp);//如果中途将指针buffer_temp被修改,会导致释放错误,地址指针要保护好
b、对于错误1,是由于内存被越界处理导致。
例如使用memset时,指定memset的长度超过了申请的内存长度,导致处理越界。
int * buffer_temp2 = (int*)calloc(length,sizeof(int));
错误:memset(buffer_temp2, 0,sizeof(point2i)*length);//sizeof(point2i)*length
>sizeof(int)*length
错误:memset(buffer_temp2, 0,sizeof(int)*(length+n));
总结:申请和释放内存要对应,类型要注意;运用memset高速赋值时,注意处理区域长度;当出现申请内存出现错误时,很有可能是该内存没有被申请便被越界使用了,导致申请该片内存时造成冲突。
驴儿先生笔记,不断更新中zzz...
网友评论