摘自:https://blog.csdn.net/u013457167/article/details/82814413
常见内存错误
1、内存尚未分配成功,却使用了它
【解决办法】在使用内存之前检查指针是否为NULL,或者说,在使用指针之前一定要确保指针是有效的,即要进行指针有效性检验。如果指针p是函数的参数,那么在函数的入口使用assert(p != NULL) 进行检查,如果是用malloc或者new来申请的,应该用 if (p == NULL) 或者 if (p != NULL) 来进行防错处理。
【问题】指针检验时,assert(NULL!=p)与if(NULL!=p)的区别?
assert是一个宏,包含在assert.h头文件中。命令assert(NULL!=p)的逻辑值为假时,程序终止运行,并提示错误;如果逻辑值为真,则继续运行后面的代码。assert这个宏仅仅在Debug版本上起作用,在Release版本中被编译器完成优化掉。所以assert这个宏只是帮助我们调试代码的,它的作用是:让用户在调试函数的时候把错误排除掉,而不是等待Release之后。assert可以帮助定位错误,而不是排除错误。
if(NULL!=p)是在Release版本中检验指针的有效性。
2、内存分配虽然成功,但是尚未初始化就引用它
【错误原因】一是没有初始化的观念,二是误以为内存的缺省初值全为零,导致引用初值错误(如数组)。
【解决办法】内存的缺省初值是什么并没有统一的标准,尽管有些时候为零值,但是宁可信其有,不可信其无,无论以何种方式创建数组,都要赋初值。
3、内存分配成功并初始化,但是超过了内存的边界
这种问题常出现在数组越界,写程序是要仔细。
4、忘记释放内存,造成内存泄露
含有这种错误的函数每次被调用都会丢失一块内存,开始时内存充足,看不到错误,但终有一次程序死掉,报告内存耗尽。
5、释放了内存却继续使用它
【产生原因】
1)程序中的对象调用关系过于复杂,难以搞清楚某个对象究竟是否已经释放了内存,此时应该重新设计数据结构,从根本上解决对象管理的混乱局面。
2)函数return语句写错了,注意不要返回指向“栈内存”的指针或者引用,因为该内存在函数体结束时理论上被自动销毁。
3)使用free或者delete释放了内存后,没有将指针设置为null,导致产生野指针。
【解决办法】小心仔细。
内存管理需要遵循的规则
1、用malloc或者new申请内存之后,应该立即检查指针值是否为NULL,防止使用指针值为NULL的内存;
2、不要忘记数组和动态内存赋初值,防止未被初始化的内存作为右值使用;
3、避免数组或者指针下标越界,特别要当心“多1”或者“少1”的操作;
4、动态内存的申请与释放必须配对,防止内存泄露;
5、用free或者delete释放了内存之后,立即将指针设置为NULL,防止产生“野指针”。