- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
9.3静态存储分配静态分配名字在程序被编译时绑定到存储单元,不需要运行时的任何支持。绑定的生存期是程序的整个运行时间。名字在程序被编译时绑定到存储单元,不需要运行时的任何支持。静态分配9.3静态存储分配名字在程序被编译时绑定到存储单元,不需要运行时的任何支持。绑定的生存期是程序的整个运行时间。控制再次进入该过程时,局部变量的值和控制上一次离开时的一样。静态分配9.3静态存储分配01020304名字在程序被编译时绑定到存储单元,不需要运行时的任何支持。绑定的生存期是程序的整个运行时间。控制再次进入该过程时,局部变量的值和控制上一次离开时的一样。每个活动记录的大小是固定的。静态分配9.3静态存储分配过程调用时保存信息的地址在编译时也是已知的。每个活动记录的大小是固定的。控制再次进入该过程时,局部变量的值和控制上一次离开时的一样。绑定的生存期是程序的整个运行时间。名字在程序被编译时绑定到存储单元,不需要运行时的任何支持。静态分配9.3静态存储分配静态分配给语言带来限制递归过程不被允许9.3静态存储分配数据对象的长度和它在内存中位置的限制,必须是在编译时可以知道的递归过程不被允许静态分配给语言带来限制9.3静态存储分配递归过程不被允许数据对象的长度和它在内存中位置的限制,必须是在编译时可以知道的数据结构不能动态建立静态分配给语言带来限制9.3静态存储分配0102如果在编译时就能够确定一个程序在运行时所需的存储空间的大小,则在编译时就能够安排好目标程序运行时的全部数据空间,并能确定每个数据项的单元地址。存储空间的这种分配方法叫做静态分配。FORTRAN程序的特点是:不允许过程的递归性;每个数据名所需的存储空间大小都是常量(即不许含可变体积的数据,如可变数组);并且所有数据名的性质是完全确定的(不允许那种需在运行时动态确定其性质的名字)。9.3静态存储分配9.4简单的栈式存储分配这种语言没有分程序结构,过程定义不许嵌套,但允许过程的递归调用。C就是这样的一种语言。9.4.1C的活动记录C的活动记录有以下四个项目。·连接数据,有两个:(1)老SP值,即前一活动记录的地址;(2)返回地址。·参数个数。·形式单元(存放实在参数的值或地址)。·过程的局部变量、数组内情向量和临时工作单元。9.4.2C的过程调用、过程进入、数组空间分配和过程返回9.5嵌套过程语言的栈式实现嵌套层次:如过程Q是在层数为i的过程P内定义,并且P是包围Q的最小过程,那么Q的层数就为i+1。sort readarray exchange quicksort partition 过程嵌套深度sort 1readarray 2exchange 2quicksort 2partition 39.5嵌套过程语言的栈式实现过程嵌套深度1sort 12readarray 23exchange 24quicksort 25partition 36变量的嵌套深度:它的声明所在过程的嵌套深度作为该名字的嵌套深度79.5嵌套过程语言的栈式实现01栈式分配02栈式分配策略在下列情况下行不通:03过程活动停止后,局部名字的值还必须维持9.5嵌套过程语言的栈式实现9.5嵌套过程语言的栈式实现栈式分配栈式分配策略在下列情况下行不通:过程活动停止后,局部名字的值还必须维持被调用者的活动比调用者的活动活得更长,此时活动树不能正确描绘程序的控制流9.5嵌套过程语言的栈式实现栈式分配栈式分配策略在下列情况下行不通:过程活动停止后,局部名字的值还必须维持被调用者的活动比调用者的活动活得更长,此时活动树不能正确描绘程序的控制流不遵守栈式规则的有Pascal语言和C语言的动态变量Java禁止程序员自己释放空间9.6堆式动态存储分配堆式的动态存储如果一个程序语言允许用户自由地申请数据空间和退还数据空间,或者不仅有过程而且有进程(process)的程序结构,那么,由于空间的使用未必服从“先请后还,后请先还”的原则,因此,栈式的动态分配方案就不适用了。在这种情况下通常使用一种称之为堆式的动态存储分配方案。9.6.1堆式动态存储分配的实现定长块管理堆式存储分配最简单的实现是按定长块进行。初始化时,将堆存储空间分成长度相等的若干块,每块中指定一个链域,按照邻块的顺序把所有块
您可能关注的文档
- 资料库行销基因演算法.ppt
- 质量监督质量认证和消费者保护.ppt
- 计划生育常见并发症的处理.ppt
- 语文题型分析.ppt
- 项目2国际结算业务中的往来银行.ppt
- 责任追究办法.ppt
- 部份偏移时间剖面波场特征.ppt
- 证会计岗位职责.ppt
- 遗传的物质基础课件.ppt
- 转换之徽章漫画.ppt
- 2024年度安永全球另类投资基金调查报告.docx
- 2024年中国汽车产业出海回顾分析 -中汽信科国际化研究团队.docx
- 【民航局国际合作服务中心】马尔代夫民航业发展研究报告.docx
- 2025走向融合与深化的中国媒介市场报告-星传媒体.docx
- 2023Givaudan和ESG目的与性能.docx
- 中国民间应对气候变化行动故事集-教育故事.docx
- 2025AI制药市场规模产业链构成应用现状及AI制药公司分析报告.docx
- 医疗器械专题之基因测序:分子诊断掌上明珠,四代测序开启规模化应用时代.docx
- 2024年中央银行黄金储备调查报告 202406.docx
- 智慧芽 -2024第4季度全球潜力靶点及FIC产品调研报告.docx
文档评论(0)