编译原理课程设计报告词法分析器.doc

编译原理课程设计报告词法分析器.doc

ID:58831466

大小:138.50 KB

页数:12页

时间:2020-09-24

编译原理课程设计报告词法分析器.doc_第1页
编译原理课程设计报告词法分析器.doc_第2页
编译原理课程设计报告词法分析器.doc_第3页
编译原理课程设计报告词法分析器.doc_第4页
编译原理课程设计报告词法分析器.doc_第5页
资源描述:

《编译原理课程设计报告词法分析器.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、课程设计任务书目录引言...............................................................4第一章概述.....................................................51.1设计内容....................................................51.2设计要求...................................................5第二章设计的基本原

2、理...........................................62.1............................................................62.2............................................................6第三章程序设计.................................................73.1总体方案设计.......................

3、........................73.2各模块设计.................................................8第四章程序测试.................................................94.1一般测试4.2出错处理测试第五章结论.....................................................10参考文献..........................................

4、.................10附录程序清单.................................................11引言《编译原理》是国内外各高等院校计算机科学技术类专业,特别是计算机软件专业的一门重要专业课程。该课程系统地向学生介绍编译程序的结构、工作流程及编译程序各组成部分的设计原理和实现技术。由于该课程理论性和实践性都比较强,内容较为抽象复杂,涉及到大量的软件设计算法,因此,一直是一门比较难学的课程。为了使学生更好地理解和掌握编译技术的基本概念、基本原理和实现方法,实践环节非常

5、重要,只有通过上机进行程序设计,才能使学生对比较抽象的教学内容产生具体的感性认识,增强学生综合分析问题、解决问题的能力,并对提高学生软件设计水平大有益处。编译原理涉及词法分析,语法分析,语义分析及优化设计等各方面。词法分析阶段是编译过程的第一个阶段,是编译的基础。这个阶段的任务是从左到右一个字符一个字符地读入源程序,即对构成源程序的字符流进行扫描然后根据构词规则识别单词(也称单词符号或符号)。词法分析程序实现这个任务。词法分析程序可以使用Lex等工具自动生成。从左到右逐个字符对构成源程序的字符串进行扫描,依据词法规则,

6、识别出一个一个的标记(token),把源程序变为等价的标记串序列。执行词法分析的程序称为词法分析器,也称为扫描器。词法分析是所有分析优化的基础,涉及的知识较少,如状态转换图等,易于实现。本次课程设计,我的选题是词法分析,C++代码实现。第一章概述1.1设计内容对C语言的一个子集设计并实现一个简单的词法分析器,掌握利用状态转换图设计词法分析器的基本方法。1.2设计要求利用该词法分析器完成对源程序字符串的词法分析。输出形式是源程序的单词符号二元式的代码,并保存到文件中。(1)假设该语言中的单词符号及种别编码如下表所示。单词

7、符号及种别编码单词符号种别编码单词符号种别编码main1[28int2]29char3{30if4}31else5,32for6:33while7;34标识符ID10>35整型常数NUM20<36=21>=37+22<=38-23==39*24!=40/25&41(26&&42)27

8、

9、43(2)关键字mainintcharifelseforwhile都是小写并都是保留字。算符和界符=+-*/&<<=>>=== !=&&

10、

11、,:;{}[]()ID和NUM的正规定义式为:ID→letter(letter

12、didit)*N

13、UM→digitdigit*letter→a

14、…

15、z

16、A

17、…

18、Zdigit→0

19、…

20、9如果关键字、标识符和常数之间没有确定的算符或界符作间隔,则至少用一个空格作间隔。空格由空白、制表符和换行符组成。第二章设计原理2.1符号分类程序语言的单词符号一般分为以下五种:关键字标识符常数运算符界符2.2.词法分析器的二元输出(单词种别,单词

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。