词法分析实验报告.pdfVIP

  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文档。上传文档
查看更多
编译原理实验一 姓 名:朱彦荣 学 号 专 业:软件工程2 实验题目:词法分析 完成语言:C/C++ 上级系统:VC++6.0 日 期:2015/11/7 词法分析 设计题目:手工设计 c 语言的词法分析器 (可以是 c 语言的子集) 设计内容: 处理 c 语言源程序,过 掉无用符号,判断源程序中单词的合法 性,并分解出正确的单词,以二元组形式存放在文件中。 设计目的: 了解高级语言单词的分类,了解状态图以及如何表示并识别单词 规则,掌握状态图到识别程序的编程。 结果要求:课程设计报告。 完成日期:第十五周提交报告 一. 分析 要想手工设计词法分析器,实现 C 语言子集的识别,就要 明白什么是词法分析器,它的功能是什么。词法分析是编译程 序进行编译时第一个要进行的任务,主要是对源程序进行编译 预处理(去除注释、无用的回车换行找到包含的文件等)之后,对 整个源程序进行分解,分解成一个个单词,这些单词有且只有 五类,分别是标识符、保留字、常数、运算符、界符。以便为下 面的语法分析和语义分析做准备。可以说词法分析面向的对象 是单个的字符,目的是把它们组成有效的单词(字符串);而语法 的分析则是利用词法分析的结果作为输入来分析是否符合语 法规则并且进行语法制导下的语义分析,最后产生四元组(中间 代码),进行优化(可有可无)之后最终生成 目标代码。可见词法 分析是所有后续工作的基础,如果这一步出错,比如明明是‘=’ 却被拆分成‘’和‘=’就会对下文造成不可挽回的影响。因此,在 进行词法分析的时候一定要定义好这五种符号的集合。下面是 我构造的一个 C 语言子集。 第一类 :标识符 letter(letter | digit)* 无穷集 第二类 :常数 (digit)+ 无穷集 第三类 :保留字(32) auto break case char const continue default do double else enum extern float for goto if int long register return short signed sizeof static struct switch typedef union unsigned void volatile while 第四类 :界符 ‘/*’ 、‘//’、 () { } [ ] 等 第五类 :运算符 、=、、=、=、+、-、*、/、^、等 对所有可数符号进行编码: $,0 auto,1 ... while,32 +,33 -,34 *,35 /,36 ,37 =,38 ,39 =,40 =,41 ==,42 !=,43 ;,44 (,45 ),46 ^,47 ,,48 ,49 ,50 #,51 ,52 ,53 |,54 ||,55 %,56 ~,57 ,58左移 ,59右移 [,60 ],61 {,62 },63 \,64 .,65 ?,66 :,67 !,68 [,],{,} 常数 99

文档评论(0)

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

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

1亿VIP精品文档

相关文档