编译原理第8章_存储空间组织.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

§8.4.3C的活动记录TOP→临时单元内情向量局部变量形式单元参数个数返回地址SP→老SP←动态链连接数据参数TOP→临时单元内情向量局部变量形式单元参数个数返回地址SP→老SPIntxMain(){x=10;R;…}VoidR(intc){intb,M[3];b=5;M[c]=x+2;ifM[c]5Q;}VoidQ(){…R(1);…}临时变量T1第1维维长d1M维数:1M起始地址a局部变量:b形参:c参数个数:1返回地址老SP过程R的活动记录L=9§8.4.4主要处理工作1.C语言过程调用过程调用中间代码:parT1…parTnCallP,n(n为参数个数)+4形式单元+3参数个数+2返回地址+1老SPTOP→QSP→R1main全局数据区对:ParTi(i=1~n),目标代码:传地址:(i+3)[TOP]:=Addr[Ti]或传值:(i+3)[TOP]:=Ti对:CallP,n目标代码:*1[TOP]:=SP(保护工作环境)*参数个数:3[TOP]:=n*转子:JSRPIntxMain(){x=10;R;…}VoidR(intc){intb,M[3];b=5;M[c]=x+2;ifM[c]5Q;}VoidQ(){…R(1)——L处…}调用顺序Main↓R1↓Q↓R2调用过程R的中间代码:par1callR,1IntxMain(){x=10;R;…}VoidR(intc){intb,M[3];b=5;M[c]=x+2;ifM[c]5Q;}VoidQ(){…R(1)——L处…}104形参c1103参数个数1102101老SP50100TOP→Q99SP→50R1mainX10全局数据区调用顺序过程调用中间代码:par1callR,1对:ParTi(i=1~n)(i+3)[TOP]:=Addr[Ti](或Ti)对:CallP,n*1[TOP]:=SP*3[TOP]:=n(参数个数)*JSRP(转子)Main↓R1↓Q↓R22.过程进入过程定义的中间代码:proc过程名过程体return(m)endproc过程进入新TOP→…形式单元参数个数+1返回地址新SP→老SP(Q的SP)TOP→QSP→R1main全局数据区⑴建立新的工作环境(SP,TOP)⑵保护返回地址目标代码:SP:=TOP+1(新SP)1[SP]=返回地址TOP:=TOP+L(新TOP)L:过程活动记录大小,静态确定IntxMain(){x=10;R;…}VoidR(intc){intb,M[3];b=5;M[c]=x+2;ifM[c]5Q;}VoidQ(){…R(1)…}TOP→108107106105104形参c1103参数个数1102返回地址101SP→老SP50100TOP→Q99SP→50R1mainX10全局数据区调用顺序过程进入Main↓R1↓Q↓R2SP:=TOP+11[SP]=返回地址TOP:=TOP+L3.数组分配空间⑴将TOP+1填入数组内情向量的a处(起始地址);⑵数组大小=M,TOP:=TOP+MVoidR(intc){intb,M[3];b=5;M[c]=x+2;ifM[c]5Q;}TOP→M[2]111↑M[1]110数组区M[0]109↓TOP

文档评论(0)

翰林大当家 + 关注
实名认证
服务提供商

文案个性定制,计划书、方案、策划书专业撰写。

1亿VIP精品文档

相关文档