- 1、本文档共126页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
8.5.1 无过程嵌套的静态作用域 C语言的函数声明不能嵌套,函数不论在什么情况下激活,要访问的数据分成两种情况: 非静态局部变量(包括形式参数),它们分配在活动记录栈顶的那个活动记录中 外部变量(包括定义在其它源文件中的外部变量)和静态的局部变量,它们都分配在静态数据区 堆区空间分配策略 最佳适应策略 总是将请求的内存分配在满足要求的最小可用孔洞中 倾向于将大孔洞预留起来以便用来满足后续的更大请求,这是令程序产生最少碎片的一种很好的堆分配策略 堆区空间分配策略 首次适应策略 将请求的内存分配在第一个满足要求的孔洞中 这种策略在分配空间时所花费的时间较少,但在总体性能上要低于最佳适应策略 堆区空间分配策略 如果将空闲块按大小不同放入不同的桶中,则可以更有效地实现最佳适应策略 桶机制更容易按最佳适应策略找到所需的空闲块: 如果被请求的空闲块尺寸对应有一个专用桶,,则从该桶中任意取出一个空闲块即可 如果被请求的空闲块尺寸没有对应的专用桶,则找一个允许存放所需尺寸空闲块的桶。在桶中使用首次适应策略或者最佳适应策略寻找满足要求的空闲块 如果目标桶是空的,或者桶中没有满足要求的空闲块,则需要在稍大的桶中进行搜索 空闲空间管理策略 如果通过手工方式释放某个对象所占用的内存块,则内存管理器必须将其设置为空闲的,以便它可以被再次分配。为了减少碎片的产生,如果回收的内存块在堆中的相邻块也是空闲的,则需要将它们合并成更大的空闲块。 可以使用下面的两种数据结构来接合相邻的空闲块 边界标签 双向链接的空闲块列表 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 5. 过程返回时,执行下述指令: TOP:=SP-1 SP:=0[SP] X:=2[TOP] UJ 0[X] 参数个数 返回地址 形式单元 临时单元 内情向量 局部变量 老SP Display 表 全局Display TOP? SP ? 调用过程的 活动记录 …… TOP? SP ? 过程调用、过程进入、过程返回 * * 8.5.3 动态作用域的实现 从技术上讲,如果作用域策略需要基于程序运行时才能知道的因素,则任何作用域策略都将是动态的。但“动态作用域”这个术语通常是指下面的策略:名字x的引用指向带有x声明的最近被调用的过程中x的这个声明。 在某种意义上说,动态作用域规则相对于时间,而静态作用域规则相对于空间。 * * 8.5.3 动态作用域 程序运行时,一个名字a实施其影响,直到含a的声明的一个过程开始执行时暂停,此过程停止时,该影响恢复。 设有下面的的调用序列: A ? B ? C ? P 过程P中有对x的非局部引用,沿动态链(红链)查找,最先找到的便是。 * * 8.5.3 动态作用域 program dynamic(input, output); var r: real; procedure show; begin write(r: 5: 3) end; procedure small; var r: real; begin r := 0.125; show end; begin 静态作用域 r := 0.25; 0.250 0.250 show; small; writeln; 0.250 0.250 show; small; writeln end. dynamic show small small show show show * * 8.5.3 动态作用域 program dynamic(input, output); var r: real; procedure show; begin write(r: 5: 3) end; procedure small; var r: real; begin r := 0.125; show end; begin 动态作用域 r := 0.25; 0.250 0.125 show; small; writeln; 0.250 0.125
您可能关注的文档
- 课堂教学有效性(吴蓉)..ppt
- 课堂游戏(葵花宝典).ppt
- 课堂规范班会好.ppt
- 第5课友情伴我行项目1《播种友情》.ppt
- 课外古诗词十首.ppt
- 课外古诗词背诵(八年级上册语文) (2).ppt
- 第6章(新新新).ppt
- 课外古诗词背诵.ppt
- 课外文言文总复习.ppt
- 第6章古地理分析与编图.ppt
- 艾瑞咨询-2025年中国舒适眼镜白皮书.pptx
- 专题01 Units 4-6 重点语法归纳 七年级英语上学期期末考点(仁爱科普版2024).pptx
- 安全生产事故隐患大排查“百日攻坚”行动方案.PDF
- 第8课 欧洲的思想解放运动 课件高一下学期统编版(2019)必修中外历史纲要下(3).pptx
- 机械制图相关知识C语言及投影法等内容测试试卷.docx
- 第8课 欧洲的思想解放运动高一下学期统编版(2019)必修中外历史纲要下.pptx
- 第8课 现代社会的移民和多元文化 课件-高二历史统编版(2019)选择性必修三.pptx
- AIGC赋能高职“汽车新媒体营销”课程的应用探索.pdf
- 第8课 中国古代的法治与教化 课件-高三历史统编版(2019)选择性必修1一轮复习.pptx
- 21(null)大型购物中心 室内空气质量 解决方案.pdf
最近下载
- 室外管道支架钢结构工程施工组织设计.doc VIP
- 小学班队工作原理与实践 班队活动组织与设计.ppt VIP
- 实训6:配置故障转移群集服务.doc VIP
- 二手路面铣刨机销售合同6篇.docx VIP
- 桥式起重机司机(高级)职业技能鉴定考试题库(职校培训).docx VIP
- 人教版新目标(goforit)英语八年级下册英语全册教案.docx VIP
- (智慧工地)智慧工地标准化方案.pptx VIP
- 人教版(2025) 必修第三册 Unit 3 Diverse Cultures Reading for Writing课件(共19张PPT)(含音频+视频).pptx VIP
- 地铁项目智慧工地建设方案.docx VIP
- 2023年南昌大学计算机科学与技术专业《计算机组成原理》科目期末试卷A(有答案).docx VIP
文档评论(0)