《编译原理》课程设计说明书WHILE循环语句的翻译程序设计.doc
《《编译原理》课程设计说明书WHILE循环语句的翻译程序设计.doc》由会员分享,可在线阅读,更多相关《《编译原理》课程设计说明书WHILE循环语句的翻译程序设计.doc(21页珍藏版)》请在三一办公上搜索。
1、附件1:学 号: 课 程 设 计题 目WHILE循环语句的翻译程序设计学 院计算机科学与技术学院专 业计算机科学与技术班 级计算机0702姓 名指导教师 2010年1月8日课程设计任务书学生姓名: 专业班级: 计算机0702班 指导教师: 工作单位:计算机科学与技术学院 题目: WHILE循环语句的翻译程序设计(LR方法、输出三地址表示) 初始条件:理论:学完编译课程,掌握一种计算机高级语言的使用。实践:计算机实验室提供计算机及软件环境。如果自己有计算机可以在其上进行设计。要求完成的主要任务: (包括课程设计工作量及其技术要求,以及说明书撰写等具体要求)(1) 写出符合给定的语法分析方法的文法
2、及属性文法。(2) 完成题目要求的中间代码三地址表示的描述。(3) 写出给定的语法分析方法的思想,完成语法分析和语义分析程序设计。(4) 编制好分析程序后,设计若干用例,上机测试并通过所设计的分析程序。(5) 设计报告格式按附件要求书写。课程设计报告书正文的内容应包括:1 系统描述(问题域描述);2 文法及属性文法的描述;3 语法分析方法描述及语法分析表设计;4 按给定的题目给出中间代码形式的描述及中间代码序列的结构设计;5 编译系统的概要设计;6 详细的算法描述(流程图或伪代码);7 软件的测试方法和测试结果;8 研制报告(研制过程,本设计的评价、特点、不足、收获与体会等);9 参考文献(按
3、公开发表的规范书写)。时间安排:设计安排一周:周1、周2:完成系统分析及设计。周3、周4:完成程序调试及测试。周5:撰写课程设计报告。设计验收安排:设计周的星期五第1节课开始到实验室进行上机验收。设计报告书收取时间:设计周的次周星期一上午10点。指导教师签名: 2009年 11月 23日系主任(或责任教师)签名: 2009年 11月 23日1.系统描述 自定义while循环句型的文法及其属性文法,并用LR法为该文法设计、编制、调试一个语法及语义分析程序,并在过程中实现词法分析、语法分析,最终以三地址码的形式将形成的中间代码输出。2.文法及属性文法的描述21 文法的描述该文法的产生式如下所示:S
4、-while(A)B;A-CDCC-a|b D- =| B-a=E B-B; E-EFE E-(E) E-a|b F-+|-|*|/ 其中while、( 、) 、 、 、;、a 、b、=、=、+、-、*、/ 均为终结符,而S、A、B、C、D、E、F这些大写字母均为非终结符。D表示比较运算符,F表示算术运算符。22 属性文法的描述对该文法的属性文法描述如下:(1) S-while(A)B; prinf(if A goto B else goto next)(2) A-CDC printf(A.val = C1.val D C2.val) (3) C-a|b C.val = a | b(4) D-
5、 =| D.val = =| (5) B-a=E B.val =a.val = E.val (6) B-B; printf(B = i1.Val T i2.Val)(7) E-EFE printf(E.val = E1.val F E2.val) (8) E-(E) printf(E.place=E1.place)(9) E-a|b E.val = a | b(10)F-+|-|*|/ F.val = +|-|*|/ 3. 语法分析方法描述及语法分析表设计3.1语法分析方法的描述3.1.1 LR分析法基本概述LR分析法的归约过程是规范推导的逆过程,所以LR分析过程是一种规范归约过程。LR分析法
6、正是给出一种能根据当前分析栈中的符号串(通常以状态表示)和向右顺序查看输入串的K个(K0)符号就可唯一地确定分析器的动作是移进还是归约和用哪个产生式归约,因而也就能唯一地确定句柄3.1.2 LR分析器分析过程1.首先将初始状态 S0及句子的左界符#分别压入状态栈和符号栈中。2.设在分析中的某一步,分析栈及余留的输入串为如下格局: S0S1 Sm ai ai+1an #X1 Xm 则用栈顶状态Sm和当前扫描符 ai组成符号对( Sm, ai)去查分析动作表,根据ACTIONSm, ai的指示完成相应的分析动作。表中每一表元素所规定的动作仅能是下列四种动作之一:(1) ACTIONSm, ai=
7、Sm+1 (移进)表明句柄尚未在栈顶形成,此时正期待移进输入符号以便形成句柄。故将当前的输入符号和表元素Sm+1分别压入栈中(2) ACTIONSm, ai= Rj (归约)表明此时应按文法的第j个产生式A Xm-k+1Xm-k+2 Xm 进行归约。即栈顶符号串Xm-k+1Xm-k+2 Xm已成为当前句型的句柄。所谓按第j个产生式归约,就是将分析栈中从顶向下的k个符号退栈,然后将文法符号A压入符号栈中。然后以( Sm-k,A)去查状态转移表,设GOTOSm-k,A= Sl ,则将此新状态压入状态栈中。(3) ACTIONSm, ai=acc (接受)表明当前的输入串已被成功地分析完毕,应停止分
8、析器的工作。(4) ACTIONSm, ai=ERROR(空白)。 表明当前的输入串中含有错误,也应终止当前的分析工作。转出错处理3. 重复上述第2步的工作,直到分析栈顶出现“接受状态”或“出错状态“为止。3.2 LR分析表设计构造3.2.1 已定义文法的DFA如图3.2.13.2.2 文法的分析表见表3.2.2分析表注释:a代表 a|b+代表 +|-|*|/=代表 =|a|bEF(E;F)E)(a|bEFa|b|W (A)B;A-CDCC-a|bI4: C- a|bI6: S-W (B)EI5: A-CDCD-|CDCC- a|bI20: E-EFEE-(E)E-EFEE-a|bI14: B
9、-a=EE-(E)E-EFEE-a|bI21: E-EFEI22: E- (E)I13: B-a=EI16: E-EFEF-+|-|*|/ I15: B-a=EI18: E-a|bI17: E- (E)E-(E)E-EFEE-a|bSW(a|bB;E;(=EFCaI8: A-CDCI0: S-SS -w(A)B;I2: S-W (A)B;I1:S-SI9:S-W (A)B;I10:S-W (A) B;I11:S-W (A) B;B-a=EB-B;I12:S-W (A) B;B-B;I24:S-W(A)B;B-B;I25:S-W(A)B;I23:E- (E)图3.2.1: 文法的DFA分析表的A
10、CTION部分状态w();aS流程图如下:5.2 语法分析语法分析是编译过程的核心部分。它的任务是在词法分析识别出单词符号串的基础上,分析并判定程序的语法结构是否符合语法规则。流程图如下:输入串#cic1Sp#XiSi总 控 程 序输出ACTION表GOTO表栈结束其中SP为栈顶指针,Si为状态栈,Xi为文法符号栈。状态转换表内容按关系GOTOSi,X=Sj确定,改关系式是指当前栈顶状态为Si遇到当前文法符号为X时应转向状态Sj。X为终结符或非终结符。5.3 语法制导翻译在语法分析过程中,随着分析的步步进展,根据每个产生式所对应的语义子程序(或语义规则描述的语义动作)进行翻译。属性文法的每个符
11、号有属性,所以每个符号入栈时,必须连属性一起入栈,这样,栈符号就由文法符号及存放该符号属性的域所组成。由于属性类型不同,属性域存放的内容就要根据属性的类型来定。有的可能直接存放属性值,也有的存放的是指向属性值的指针。对于综合属性,其属性域不存放其属性值,而是存放一个指针,指向存贮该属性值的单元。对于继承属性,其属性域直接保存其属性值。继承属性的属性域刚入栈时为空,但是在该栈符号变成栈顶符号之前的某一时刻,它们必须接受相应的属性值,即在成为栈顶时,继承属性的属性域必须有值。6 详细的算法描述主要是词法分析与LR语法分析部分(包含主体程序干,对于调用的函数略去)词法分析主体:int cifa()o
12、fstream fout;fout.open(词法分析.txt,ios:out);if(!fout)cout词法分析文件打开失败!endl;fout.close();/将词法分析文件置空ifstream fin;fin.open(源文件.txt);if(!fin)cout打开源文件失败!endl;/源文件打开char temp120;for(int i=0;i20;i+)temp1i=0;/temp1用来记录非符号串且初始值均置空char temp2;i=0;while(!fin.eof()&temp2!=)fin.get(temp2);if(Isfuhao(temp2)/当读入的是符号时,分
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译原理 编译 原理 课程设计 说明书 WHILE 循环 语句 翻译 程序设计
链接地址:https://www.31ppt.com/p-2385797.html