标签:
为了防止内存泄露,养成检测内存分配/释放是否成功的良好习惯:
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