词法分析器实验报告及源代码.docxVIP

  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文档。上传文档
查看更多
数学与软件科学学院 实验报告 学期:13 至 14__ 第_2 学期 2014 年 3 月 17 日 课程名称:编译原理 实验编号:01 实验项目:词法分析器 专业:2011 级 5_班 指导教师_王开端 姓名:张世镪 学号: 2011060566 实验成绩: 一、目的 学习编译原理,词法分析是编译的第一个阶段,其任务是从左至右挨个字符地对源程序进 行扫描,产生一个个单词符号,把字符串形式的源程序改造成单词符号串形式的中间程序。 执行词法分析的程序称为词法分析程序,也称为词法分析器或扫描器。词法分析器的功能 是输入源程序,输出单词符号 做一个关于 C 的词法分析器,C++实现 二、任务及要求 1.词法分析器 产生下述 C 的单词序列 这个 C 的所有的单词符号,以及它们的种别编码和内部值如下表: 单词符号及种别编码 单词符号 种别编码 单词符号 种别编码 main 1 [ 28 int 2 ] 29 char 3 { 30 if 4 } 31 else 5 , 32 for 6 : 33 while 7 ; 34 标识符 ID 10 > 35 整型常数 NUM 20 < 36 = 21 >= 37 + 22 <= 38 - 23 == 39 * 24 != 40 / 25 41 ( 26 42 ) 27 || 43 关键字 main int char if else for while 都是小写并都是保留字。算符和界符 = + - * / < <= > >= == != || , : ; { } [ ] ( ) ID 和 NUM 的正规定义式为: ID→letter(letter | didit)* NUM→digit digit* letter→a | … | z | A | … | Z digit→ 0 | … | 9 如果关键字、标识符和常数之间没有确定的算符或界符作间隔,则至少用一个空格作 间隔。空格由空白、制表符和换行符组成。 三、大概设计 1. 设计原理 词法分析的任务:从左至右逐个字符地对源程序进行扫描,产生一个个单词符号。 理论基础:有限自动机、正规文法、正规式 词法分析器又称扫描器:执行词法分析的程序 2. 词法分析器的功能和输出形式 功能:输入源程序、输出单词符号 程序语言的单词符号一般分为以下五种:关键字、标识符、常数、运算符、界符。 3. 输出的单词符号的表示形式: (单词种别,单词符号的属性值) 单词种别用整数编码,关键字一字一种,标识符统 归为一种,常数一种,各种符号各一种。 4. 状态转换图实现 初始化文件指针将字符加入字符数 组 初始化文件指针 将字符加入字符数 组Word[] 打开源文件 跳过该字符 将字符加入字符数 组Word[] 将字符 加入字 符数组 Word[] 指向下一字符 识别指针内容 指向下一字符 将word与关键 字表key进行匹 配 将字符加 入字符数 组Word[] 指向下一字符 识别指针内容 回退 指向下一字符 将字符 加入字 符数组 Word[] 三、程序设计 1. 词法分析器的流程图 开始 输入源文 件路径 否 路径是否有 效 是 文件结束? 否  是  结束 是空格,空白或换 行吗  否  是字母吗  否  是数字吗  否  是界符吗  否 是 是  是 是 是 是字母惑数字 吗 否 输出word 为界符 输出Word 内容为不 可识别 是数字吗 否 输出word为 普通标示符  否  匹配?  输出word 为常数 是 输出word 为关键字 2. 总体模块设计 /*用来存储目标文件名*/ string file_name; /*提取文本文件中的信息。*/ string GetText(); /*获得一个单词符号,从位置 i 开始查找。   //并且有一个引用参数 j,用来返回这个单词最后一个字符在 str 的位置。*/ string GetWord(string str,int i,int j); /*这个函数用来除去字符串中连续的空格和换行 int DeleteNull(string str,int i); /*判断 i 当前所指的字符是否为一个分界符,是的话返回真,反之假*/ bool IsBoundary(string str,int i); /*判断 i 当前所指的字符是否为一个运算符,是的话返回真,反之假*/ bool IsOperation(string str,int i); /*此函数将一个 pair 数组输出到一个文件中*/ void OutFile(vectorpairint,string v); /*此函数接受一个字符串数组,对它进行词法分析,返回一个 pair 型数组*/ vectorpa

文档评论(0)

liushuixian + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档