标签:
为了防止内存泄露,养成检测内存分配/释放是否成功的良好习惯:
1,动态分配内存的时候检测是否分配成功,如果不成功请返回友好提示~
2,释放内存的时候将释放后的内存指针指向NULL,以保证不能被访问~
因为释放内存后,系统只是回收了指针所指的内存,此时指针是一个野指针本身仍是合法的,(只有有些类似void*的指针了),访问野指针程序当然出现异常~!
例子1:malloc()和free()函数
type*p;
if(NULL==(p=(type*)malloc(sizeof(type)))){ <span style="font-family: Arial, Helvetica, sans-serif;">/*请使用if来判断,这是有必要的*/</span>
perror("error...");
exit(1);
}
.../*其它代码*/
free(p);
p=NULL;/*请加上这句*/
例子2:new和delete操作符
但是对于C++中的new操作符,则没有必要检测是否new成功~参考:http://www.cqtarena.com/cjswz/20121106/1225.html
int* p = new int[SIZE];
if ( p == 0 ) // 检查 p 是否空指针
return -1;
...//其它代码其实,这里的 if ( p == 0 ) 完全是没啥意义的。try {
int* p = new int[SIZE];
...//其它代码
} catch ( const bad_alloc& e ) {
return -1;
}
delete [] it->second->data;it->second->data = NULL; delete it->second;it->second = NULL;
in a model,you should write the code like this a int *a=new int(5) delete a a=null b int *a=new int[5] delete a[] a=null
标签:
原文地址:http://blog.csdn.net/rangf/article/details/42168187