常见的内存错误及其对策

上传人:ji****72 文档编号:56641913 上传时间:2018-10-14 格式:PPT 页数:15 大小:310.50KB
返回 下载 相关 举报
常见的内存错误及其对策_第1页
第1页 / 共15页
常见的内存错误及其对策_第2页
第2页 / 共15页
常见的内存错误及其对策_第3页
第3页 / 共15页
常见的内存错误及其对策_第4页
第4页 / 共15页
常见的内存错误及其对策_第5页
第5页 / 共15页
点击查看更多>>
资源描述

《常见的内存错误及其对策》由会员分享,可在线阅读,更多相关《常见的内存错误及其对策(15页珍藏版)》请在金锄头文库上搜索。

1、常见的内存错误及其对策,特点 编译器不能自动发现这类错误,通常是在程序运行时才能捕捉到 时隐时现,无明显症状 分类 内存分配未成功,却使用了它 内存分配成功,但是尚未初始化就引用它 内存分配成功,并且已经初始化,但操作越过了内存的边界 忘记了释放内存,造成内存泄漏 释放了内存,却继续使用它,常见的内存错误及其对策,常见错误1: 内存分配未成功,却使用了它 起因 没有意识到内存分配会不成功 编程新手容易犯 解决对策 在使用内存之前,检查指针是否为空指针(NULL)if (p = NULL) printf(“No enough memory!n“);exit(0); ,常见的内存错误及其对策,常见

2、错误2: 内存分配成功,但是尚未初始化就引用它 起因 没有初始化的观念 误以为内存的默认值全为0 解决对策 即使是赋0值也不可省略,不要嫌麻烦,常见的内存错误及其对策,常见错误3: 内存分配成功,并且已经初始化,但操作越过了内存的边界 例如:使用数组时经常发生下标“多1”或者“少1”的操作 解决对策: 在for语句中,注意循环次数不要搞错,常见的内存错误及其对策,常见错误4: 忘记释放内存,造成内存泄漏(Memory Leak) “内存泄露”一词类似“原料泄露” 泄露出去的原料不能被利用,导致生产过程中原料不足 好比借东西不还 如果申请来的内存不用,别的程序也不能用,就好像这块内存泄露出去一样

3、,造成浪费,常见的内存错误及其对策,特征 含有这种错误的函数,每被调用一次,就丢失一块内存(制造内存垃圾) 刚开始时,系统内存充足,看不到任何错误 当系统运行相当一段时间后,就会突然死掉,出现提示:内存耗尽 需长期稳定运行的服务程序对内存泄漏最敏感 严重程度取决于 每次遗留内存垃圾的多少 代码被调用的次数,常见的内存错误及其对策,解决对策 在需要的时候才malloc,并尽量减少malloc的次数 malloc的执行效率就不高,过多的malloc使程序性能下降 能用自动变量解决的问题,就不要用malloc来解决 malloc一般在大块内存分配和动态内存分配时使用 重复使用malloc申请到的内存

4、 尽量让malloc和与之配套的free在一个函数或模块内 尽量把malloc集中在函数的入口处,free集中在函数的出口处 以上做法只能尽量降低产生泄露的概率。完全杜绝内存泄露,关键要靠程序员的细心与责任感,一个例子,void Init(void) pszMyName=(char*)malloc(256);if (pszMyName = NULL)return;pszHerName=(char*)malloc(256);if (pszHerName = NULL)return;pszHisName=(char*)malloc(256);,if (pszHisName = NULL)retur

5、n; free(pszMyName);free(pszHerName);free(pszHisName);return; ,错在哪里!,一个例子,void Init(void) pszMyName=(char*)malloc(256);if (pszMyName = NULL)return;pszHerName=(char*)malloc(256);if (pszHerName = NULL)free(pszMyName);return;pszHisName=(char*)malloc(256);,if (pszHisName = NULL)free(pszMyName);free(pszHe

6、rName);return; free(pszMyName);free(pszHerName);free(pszHisName);return; ,常见的内存错误及其对策,常见错误5: 释放了内存,却继续使用它起因: 指针所指的内存被释放以后,并不表示指针会消亡 其地址仍然不变(非NULL),只是该地址对应的内存是垃圾 指向垃圾内存的指针是“野指针”, free(ptr); if (ptr != NULL) /不起作用 ,常见的内存错误及其对策,char* GetInput(void) char s80; scanf(“%s“, s); return s; warning C4172: ret

7、urning address of local variable or temporary 输出乱码void GetInput(char* s) scanf(“%s“, s); ,错在哪里!,不能把局部变量的地址作为返回值返回 函数返回后,局部变量被释放,该地址的内存会被挪做它用,常见的内存错误及其对策,#include #include void GetInput(char *p) p = (char *)malloc(100); 程序崩溃,函数不能传递动态分配的内存?,void GetInput(char *p) *p = (char *)malloc(100); ,常见的内存错误及其对策

8、,常见错误5解决对策 尽量把malloc集中在函数的入口处,free集中在函数的出口处 如果free不能放在函数出口处,则指针free后立即设置为NULL 不要把局部变量的地址作为返回值返回,因为该内存在函数体结束时被自动销毁 指针要么初始化为NULL,要么是其指向合法的内存,非法内存操作,起因 内存分配未成功,却使用了它 内存分配成功,但是尚未初始化就引用它 内存分配成功,并且已经初始化,但操作越过了内存的边界 释放了内存,却继续使用它 基本特征 代码访问了不该访问的内存地址,非法内存操作,后果 宣布安乐死:“该程序执行了非法操作,即将关闭” 几乎全是由指针混乱导致的 少数情况下,如在硬件驱动程序中的内存问题会造成操作系统的死亡 最糟糕的不是系统死机,而是重要资料被窃取,

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号