- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
                        查看更多
                        
                    
                * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 下标指针cx,tx和变量dx的作用  code [cx]   table[tx]         s [t] (运行栈) cx              tx                   t(运行时栈指针) (0) jmp 0 0 (1) int  0  7         .              . (cx )  . (0)  name …adr... (1)    b       (dx)         ...   ( tx)    q          p             m b Table表的下标指针tx补充说明:   主程序 BLOCK 第1次调用block BLOCK(0,0,…)   0       0     ... BLOCK       BLOCK(LEV+1,TX,…) (递归进入分程序) LEV tx LEV tx (6) 6   (9) 1  tx是BLOCK的 实际值参     PL/0编译程序的实现     procedure gen(x:fct; y, z:integer);              	begin     if cxcxmax then(*指针越界*)        begin       write(‘program too long’);       close(fin);(*关闭文件*)       writeln;       exit        end;    PL/0编译程序的实现     with code[cx] do   begin     f:=x;(* 表示code[cx].f:=x; *)        l:=y;(* 表示code[cx].l:=y; *)         a:=z;(* 表示code[cx].a:=z; *)     end;  cx:=cx+1end (*gen*);   PL/0编译程序的实现 对分程序的定义(见教材417,437页)  procedure   						block(lev,tx:integer;fsys:symset);     var dx:integer;   (*data allocationindex*)          tx0:integer;  (*initial table index*)          cx0:integer;  (*initial code index*)         ( tx0,cx0是tx,cx的初值)     PL/0编译程序的实现 对分程序体人口的处理(见程序文本block 的过程体)    begin (*block*)        dx:=3;        tx0:=tx;   (保留当前table表指针值)        table[tx].adr:=cx;(保留当前code指针值到过程名 	                      的adr域 )        gen(jmp,0,0);(生成转向过程体入口的指令,该指令的地址      	             为cx 已保留在过程名的adr域,等生成 过程 	             体入口的指令时,再由table[tx].adr中取出 	                        cx将过程体入口返填到cx中,即  	    		                     ( jmp,0,0)的第3区域。             …    (注意dx, tx, cx的作用)                   CONST A=35,B=49;VAR C,D,E;PROCEDURE P;VAR G        table表格管理       名字                 类型                层次/值              地址         存储空间               (0)   jmp   0    0   CX      (1 )  jmp   0    0                     .                      . 记录 过程在code的入 口到table中的adr域    PL/0编译程序的实现 过程体入口时的处理 code[table[tx0].adr].a:=cx;    (过程入口地址填 写在code中) with table[tx0] do      b
                 原创力文档
原创力文档 
                        

文档评论(0)