- 1、本文档共90页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
如何使函数满足可重入性 仅使用栈上的变量或const常量; 仅依赖于调用方提供的参数; 不使用任何局部静态变量或全局非const变量; 不返回任何局部静态变量或全局非const变量; 不依赖于任何共享资源的锁; 不调用任何不可重入的函数。 什么是堆内存? 在需要时主动申请。 堆内存在程序主动放弃之前一直保持有效。 占据了进程地址空间的绝大部分 由C运行时环境(C Runtime Environment )负责管理,管理方法: 批发?零售 关于堆内存的相关C函数 用于零售堆内存的C标准库函数: malloc(size) calloc(n, size) realloc(ptr, size) free(addr) 用于批发堆内存的系统调用: brk(addr) // 将堆尾指针brk调整到指定地址 sbrk(incr) // 将堆尾指针brk增加或较少指定数值 mmap(…) 堆内存管理方法初探 int *p1 = (int*) malloc(sizeof(int)); char *p2 = (char*) malloc(sizeof(char)); …… free(p1) ; free(p2); 1000 大 基地址 长度 1000 100 自由内存区表 基地址 长度 占用内存区表 堆内存管理方法初探 int *p1 = (int*) malloc(sizeof(int)); char *p2 = (char*) malloc(sizeof(char)); …… free(p1) ; free(p2); 1000 大 基地址 长度 1004 96 自由内存区表 基地址 长度 1000 4 占用内存区表 堆内存管理方法初探 int *p1 = (int*) malloc(sizeof(int)); char *p2 = (char*) malloc(sizeof(char)); …… free(p1) ; free(p2); 1000 大 基地址 长度 1004 6 100B 89 自由内存区表 基地址 长度 1000 4 100A 1 占用内存区表 100A 最先适配算法 最佳适配算法 堆内存管理方法初探 int *p1 = (int*) malloc(sizeof(int)); char *p2 = (char*) malloc(sizeof(char)); …… free(p1) ; free(p2); 1000 大 基地址 长度 1000 10 100B 89 自由内存区表 基地址 长度 1000 4 100A 1 占用内存区表 100A 堆的紧缩问题 堆内存管理方法初探 int *p1 = (int*) malloc(sizeof(int)); char *p2 = (char*) malloc(sizeof(char)); …… free(p1) ; free(p2); 1000 大 基地址 长度 1000 100 自由内存区表 基地址 长度 1000 4 100A 1 占用内存区表 100A 空闲链表法 位图分配法 整个堆划分为大量的块(block),每个块大小相同。 每个块对应位图中的一个基本单元。每个基本单元占2bit 11表示Head,10表示Body,00表示空闲 其他动态内存分配算法 对象池 伙伴关系算法 使用malloc和free的注意事项 刚刚分配的动态内存的初始值是不确定的 不能对同一指针(地址) 连续两次进行free操作 不能对指向静态内存区(全局变量)或栈内存区(局部变量)的指针应用free (但可以对空指针NULL应用free)。 对一个指针应用free之后,它的值不会改变,但它指向了一个无效的内存区,这时称该指针为“悬空指针”。 如果没有及时释放某块动态内存,并且将指向它的指针指向了别处,就会造成“内存泄漏”。 执行malloc和free函数有一定的代价,所以对于较小的变量不应该放在动态内存之中,并且尽量避免频繁地分配和释放动态内存。 使用堆内存时的常见错误 内存分配未成功,却使用了它。 内存分配虽然成功,但是尚未初始化就引用它。(误认为初始值为0) 内存分配成功并且已经初始化,但操作越过了内存的边界。 忘记了释放内存,造成内存泄露。 释放了内存却继续使用它。 关于悬空指针 一个指针变量,如果不为NULL且没有指向有效的内存地址,都称为“悬空指针” 通过悬空指针访问其指向的内存区会使程序产生不可预知的错误。 如何避免悬空指针: 定义指针变量时坚持对其进行正确的初始化 在用free或delete释放内存之后,应及时将相应的指针置为NULL 悬空指针的例子(一) void somefuncion() { int *p; ... … … … *p = 7;
您可能关注的文档
- 疯狂数据库之巅讲述.pptx
- 真源医院地下防水工施工方案详解.doc
- 知行学堂“感恩教育”详解.ppt
- 知名公司招聘专员的培训教材(面试技巧和面试实操)详解.ppt
- 疲劳驾驶预警系统讲述.doc
- 疼痛的管理讲述.ppt
- 疼痛宣传(骨科、神经外科、泌尿外科、普外科、生产科均需要)讲述.pptx
- 直板手机LX3_MD设计建议说明_V1.0_110217详解.ppt
- 疯狂动物城》之动物小科普讲述.ppt
- 疲劳驾驶成因及预防对策讲述.doc
- 2025年押题宝典演出经纪人之《演出经纪实务》题库附完整答案详解【精选题】.docx
- 2025年押题宝典演出经纪人之《演出市场政策与法律法规》题库及完整答案详解(考点梳理).docx
- 2025年湖南省初中学业水平考试仿真密卷-道德与法治(B卷).pptx
- 第3章 一次方程(组) 综合素质评价(含答案)2025-2026学年湘教版数学七年级上册.docx
- 2025年湖南省初中学业水平考试仿真密卷-英 语(B卷).pptx
- DB11_T1293.4-2015_卫生应急最小工作单元装备技术要求第4部分:核与辐射事故处置类_北京市.pdf
- DB11_T1322.68-2019_安全生产等级评定技术规范第68部分:设施蔬菜生产企业及专业合作社_北京市.pdf
- DB11_T1322.71-2018_安全生产等级评定技术规范第71部分:社会福利机构_北京市.pdf
- DB11_T1313-2015_薄抹灰外墙外保温用聚合物水泥砂浆应用技术规程_北京市.pdf
- DB11_T1320-2023_危险场所电气防爆安全检测技术规范_北京市.pdf
文档评论(0)