- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
例:布尔表达式ab or cd and ef (1) if ab goto (4) (2) T1:=0 (3) goto (5) (4) T1:=1 (5) if cd goto (8) (6) T2:=0 (7) goto (9) (8) T2:=1 (9) if ab goto (12) (10) T3:=0 (11) goto (13) (12) T3:=1 (13) T4:=T2 and T3 (14) T5:=T1 or T4 作为条件控制的布尔表达式 条件语句 if E then S1 else S2,作为转移条件的布尔表达式E,可赋予它两个出口,一个为“真”出口,出向S1;一个为“假”出口,出向S2。 如: if (ab) then x:=x+1 if ab goto E.true goto E.false (+,x,1,T1) (:=,T1,-,x) (1) ( j,a,b,(3) ) (2) ( j,-,-,(5) ) (3) ( +,x,1,T1) (4) ( :=,T1,-,x) (5) 后继语句 作为条件控制的布尔表达式 对条件转移的布尔表达式,可将其翻译为一串跳转指令。如: if ac or bd then S1 else S2 译为: if ac goto L2 goto L1 L1: if bd goto L2 goto L3 L2: S1产生的三地址代码序列 goto Lnext L3: S2产生的三地址代码序列 Lnext: 后继语句 产生布尔表达式三地址代码的语义规则 产生式 语义规则 E?E1 or E2 E1.true:= E.true; E1.false:=newlable; E2.true:= E.true; E2.false:= E.false; E.code:=E1.code||gen(E1.false”:”)||E2.code E?E1 and E2 E1.true:= newlable; E1.false:= E.false; E2.true:= E.true; E2.false:= E.false; E.code:=E1.code||gen(E1.true”:”)||E2.code E?not E1 E1.true:= E.false; E1.false:= E.true; E.code:= E1.code; 例:ab or cd and ef if ab goto Ltrue goto L1 L1: if cd goto L2 goto Lfalse L2: if ef goto Ltrue goto Lfalse 用四元式实现三地址代码 (jnz,a,-,p)表示if a goto p (jrop,x,y,p)表示if x rop y goto p (j,-,-,p)表示 goto p 记录需回填地址的四元式,把需回填E.true的四元式拉成一链,把需回填E.false的四元式拉成一链,分别称做“真”链和“假”链。 (10) … goto E.true … (20) … goto E.true … (30) … goto E.true 则链成 (10) … goto (0) … (20) … goto (10) … (30) … goto (20) 把地址(30)称作“真”链链首,0为链尾标志,即地址(10)为“真”链链尾。 语义描述使用的变量和过程: E.truelist : “真”链, E .falselist : “假”链 。 Nextquad : makelist(i): 下一条将要产生但尚未形成的四元式的地址 emit( ): 输出一条四元式 merge(p1, p2): 把 p1 的链首填在 p2 的链尾 例: merge(p1, p2) ( p10) goto ( 0) …… p1 链
您可能关注的文档
最近下载
- 2021版35kV~750kV 变电站通用设备技术规范第13部分:接地变压器及消弧线圈成套装置.pdf VIP
- 心脏横纹肌瘤的科普知识课件.pptx VIP
- 2021版35kV~750kV 变电站通用设备技术要求及接口规范第2部分:高压并联电抗器.pdf VIP
- 新概念英语二册Mp3教程附音频下载-英语听力_0.pdf VIP
- 2021版35kV~750kV 变电站通用设备技术规范第9部分:低压并联电抗器.pdf VIP
- 2021版35kV~750kV 变电站通用设备技术规范第第12部分:站用变压器.pdf VIP
- 初一有理数计算700题.docx VIP
- 市政供热管网施工技术的方案.doc
- 循环教材制度_使用登 记表.doc VIP
- 部编小学语文六年级上册第二单元《革命岁月》集体备课教材分析解读.pptx VIP
文档评论(0)