广东工业大学编译原理课设.doc

  1. 1、本文档共12页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
广东工业大学编译原理课设

课 程 设 计 课程名称 编译原理 题目名称 对PL/0的修改与扩充 学生学院 计算机学院 专业班级 学 号 学生姓名 指导教师 2014 年 1 月 3 日 一.课程设计目的 在分析理解一个教学型编译程序(如PL/0)的基础上,对其词法分析程序、语法分析程序和语义处理程序进行部分修改扩充。达到进一步了解程序编译过程的基本原理和基本实现方法的目的。 二.课程设计要求 (1)扩充赋值运算:*= 和 /= (2)扩充语句(Pascal的FOR语句): FOR <变量>:=<表达式>STEP<表达式> UNTIL<表达式>Do<语句> 三.课程设计环境与工具 1. 程序运行环境: (1)运行平台:Windows XP (2)实现工具:Borland C++ Building 6.0 教学型编译程序:PL/0 源程序:PL/0 源代码 四.结构设计说明 PL/0编译程序的结构图 各功能模块描述 pl0 主程序 error 出错处理,打印出错位置和错误编码 getsym 词法分析,读取一个单词 getch 漏掉空格,读取一个字符 gen 生成目标代码,并送入目标程序区 test 测试当前单词符号是否合法 block 分程序分析处理过程 enter 登录名字表 position(函数) 查找标识符在名字表中的位置 constdeclaration 常量定义处理 vardeclaration 变量说明处理 listode 列出目标代码清单 statement 语句处理 expression 表达式处理 term 项处理 factor 因子处理 condition 条件处理 interpret 对目标代码的解释执行程序 base(函数) 通过静态链求出数据区的基地址 PL/0编译程序的总体流程图 主要成分描述 1、符号表 全程量一维数组。表项主要有5个:名字(NAME),类型(KIND),值/层次(VAL/LEVEL),过程名的ADR域,过程所需要的空间(SIZE)。 对于常量,变量和过程说明这三种情况,都需要把其相关的信息登记入符号表中。这三种情况需要登记到符号表的内容分别如下: (1)常量:记录下该常量的名字(TBLE.NAME),登记该名字属于常量(TABLE.KIND),记录下该常量的值(TABLE.VAL)。 (2)变量:记录该变量的名字(TABLE.NAME),记录下该名字为变量的类型(TABLE.KIND),登记下该变量所在的层次(TABLE.LEVEL),登记该变量存储位置(TABLE.ADR)。 (3)过程名:记录下该过程名字(TABLE.NAME),记录下该名字属于过程(TABLE.KIND),记录下该过程所在的层次(TABLE,LEVEL),记录下存储位置(TABLE.ADR),过程所需要的数据空间(TABLE.SIZE)。 运行时存储组织和管理 语法分析方法 中间代码表示 基本与添加关键字操作一样,只是由于这四个为运算符,不属于关键字,因此头文件中的关键字个数不用修改。 //void GetSym() else if(CH=='*'){ //添加运算符 *=    GetCh();    if(CH=='=') { SYM=MULEQL; GetCh(); } }else if(CH=='/'){ //添加运算符 /= GetCh(); if(CH=='='){ SYM=DIVEQL; GetCh(); } }else if(CH=='&'){ //添加运算符 && GetCh(); if(CH=='&'){ SYM=AND; GetCh; }else{ SYM=NUL; } }else if(CH=='|'){ //添加运算符 || GetCh(); if(CH=='|'){ SYM=OR; GetCh; }else{ SYM=NUL; } }else if(CH=='!'){ //添加运算符 ! SYM=NOT; GetCh; } ………………………………………… //void STATEMENT if (SYM==BECOMES) {GetSym(); EXPRESSION(FSYS,

文档评论(0)

peain + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档