运行时的存储组织及管理

运行时的存储组织及管理

ID:21956336

大小:219.00 KB

页数:23页

时间:2018-10-21

运行时的存储组织及管理_第1页
运行时的存储组织及管理_第2页
运行时的存储组织及管理_第3页
运行时的存储组织及管理_第4页
运行时的存储组织及管理_第5页
资源描述:

《运行时的存储组织及管理》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、运行时的存储组织及管理运行时的存储组织及管理概述存储组织运行时的存储分配策略静态存储分配动态存储分配对非局部名字的访问参数传递7/9/20212编译技术有关源程序中的一些问题问题的提出:如何构造运行程序的策略和方法过程活动树控制栈说明的作用域名字的绑定7/9/20213编译技术名字与存储的绑定名字存储单元值存储分配程序运行环境状态l-valuer-value静态概念动态对应过程定义过程活动名字说明名字的绑定说明的作用域活动的生存期7/9/20214编译技术存储组织运行时刻内存的划分:假定编译器从操作系统得到一块存储区,运行时的存储空间要划分成块:生成的目标

2、代码;数据对象;记录过程活动的控制栈对应的数据结构目标代码静态数据栈堆返回值实在参数控制链(动态链)访问链(静态链)保存机器状态局部数据临时变量7/9/20215编译技术运行时刻存储分配策略分配策略是:静态分配;栈式分配,或称栈式动态分配;堆式分配,或称堆式动态分配。采用哪种分配策略是由源语言的语义决定的。7/9/20216编译技术堆式存储分配栈式存储分配策略在下列情况下不能使用:活动结束时必须保持局部名字的值被调用者的活动比调用者的活动的生存期长。堆式存储器的策略:(堆管理器管理堆空间)把连续存储区域分成块,当活动记录或其他对象需要时就分配。块的释放可以

3、按任意次序进行,所以经过一段时间后,堆可能包含交错的正在使用的和已经释放的区域7/9/20217编译技术堆管理器的效率问题堆管理的效率问题是数据结构理论中的特殊问题对每个感兴趣的活动记录的大小,保存一个相应大小的空闲块的链表可能的话,为大小为s的请求分配一个大小为s’的块,其中s’是大小等于s的最小块。当该块最终被释放后,将其链回原来的空闲块链表对于大块存储空间,使用堆管理器管理。其具体管理方法可以参考操作系统中堆内存的管理方法。7/9/20218编译技术栈式存储分配基于控制栈的原理:存储空间被组织成栈,活动记录的推入和弹出分别对应于活动的开始和结束。与静

4、态分配不同的是,在每次活动中把局部名字和新的存储单元绑定,在活动结束时,活动记录从栈中弹出,因而局部名字的存储空间也随之消失。7/9/20219编译技术当控制流通过图6.3的活动树时活动记录被推人或弹出运行时刻的栈中的情况,设寄存器top标记栈顶。sSa:arraytoprri:integertoptopq(1,9)q(1,9)i:integertopp(1,9)p(1,9)i:integertoptopq(1,3)q(1,3)i:integertop7/9/202110编译技术栈式存储分配确定活动记录中局部数据的地址:假设top-sp标记一个活动记录的开

5、始的位置,dx表示x的地址相对于top-sp的偏移量。那么,x在过程的目标代码中的地址可写成dx(top-sp)在运行时刻,当把x的活动记录筑于栈顶时,寄存器top-sp被赋于实际的地址,top-sp可以是一个寄存器。7/9/202111编译技术调用序列和返回序列通过在目标代码中生成调用序列和返回序列实现过程的调用。激活一个过程的活动是执行过程语句的结果。过程语句p(e1,e2,……,en)的目标代码(调用序列)完成任务:调用者对实在参数求值,并把它们传送给被调用过程的活动记录的参数域。调用者在被调用者的活动记录中存放返回地址和老top-sp之值。之后调用

6、者把top一sp之值增加到新的栈顶的活动记录的位置。被调用者存放寄存器值和其它状态信息。被调用者初始化其局部数据并开始执行。……参数和返回值链和保存的状态临时变量和局部数据参数和返回值临时变量和局部数据控制链链和保存的状态控制链top_sp调用者的活动记录被调用者的活动记录调用者的任务被调用者的任务7/9/202112编译技术调用序列和返回序列返回序列,return目标代码完成的任务是:被调用者在自己的活动记录的返回值域中放一个返回值。利用状态域中的信息,被调用者恢复top-sp和其它寄存器,并且按返回地址转移到调用者的代码之中。调用者复制返回值到自己的活

7、动记录中。7/9/202113编译技术可变长度的数据源程序的例子PROCEDUREexam(l,m,n:integer);VARa:array[1..l]ofreal;b:array[1..m]ofreal;c:array[1..n]ofreal;BEGIN……END;编译时,不知a,b,c的大小,仅对每个数组设置一个指针。7/9/202114编译技术可变长度的数据ControllinkabcTop-sptopArrayaArraybArrayctopP的活动记录P的动态数组7/9/202115编译技术参数传递参数传递说明的作用域如果一个说明的作用域

8、是在一个过程里,那么这个过程里出现的该说明中的名字都是局部于本过程

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。