- 1、本文档共22页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第7章 节 运行时的存储组织与分配.ppt
第7章 运行时的存储组织与分配;S.P;7.1 存储组织概述
7.2 静态存储分配
7.3 栈式动态存储分配
7.4 堆式动态存储分配
7.5 PL/0编译程序目标代码解释执行时的存储分配
;7.1 存储组织概述;过程的活动和活动记录 ;FORTRAN程序的静态分配 ;动态存储分配;7.3 栈式动态存储分配 ;练习;7.4 堆式动态存储分配 ;7.5 PL/0目标代码解释执行时的存储分配 ;(1)程序存储器code
struct instruction{
enum fct f ;
int l;
int a;
};
struct instruction code[CXMAX+1];;(3)程序地址寄存器p
int p=0;
p是code数组的索引地址,用来存放下一条要解释执行指令在程序存储器code里的位置。在解释执行时才用到,初值为0,即第1条要解释执行的指令存放在code[0]。;(5)指令寄存器i
struct instruction i;
用来存放正在解释执行的一条目标代码指令。在解释程序里,每次通过i=code[p];和p=p+1;这两条赋值语句,完成从程序存储器code中取指令,以及使程序地址寄存器p指向下一条指令位置的任务。;活动记录;三个联系单元:
SL:静态链,指向定义该过程的直接外层过程的活动记录的基地址,以确保变量的正确存取。
DL:动态链,指向调用该过程前正在运行的那个过程的活动记录的基地址,以确保能返回到调用过程段。
RA:返回地址,保存该被调过程返回后的地址,即当时程序的地址寄存器p的值,也就是调用过程指令的下一条指令的地址,用来确保返回到正确的指令地址。 ;;以下两条指令协助cal完成过程调用和返回
ini 0 a过程目标程序的入口,开辟数据段。a为局部变量个数+3。开辟数据段的结果是改变栈顶寄存器t的值,即t=t+a。
在block中调用statement之前调用gen(ini,0,dx);
opr 0 0过程目标程序的出口,释放数据段。恢复调用该过程前正在运行的过程的数据段基地址寄存器的值和栈顶寄存器的值,并将返回地址送到地址寄存器p中,以使调用前的程序从断点开始继续执行。
在block中调用statement之后调用gen(opr,0,0);
;小结;习题1(1)—(4)、2、3、7
文档评论(0)