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

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

ID:44959756

大小:239.50 KB

页数:6页

时间:2019-11-06

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

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

1、一.课程设计题目:词法分析器的实现二.课程设计成员三.课程设计内容和要求设计一个程序,调试、编译,实现词法分析的功能,识别各单词或字符所属类别,并显示在屏幕上。词法分析器:逐个读入源程序字符并按照构词规则切分成一系列单词。单词是语言中具有独立意义的最小单位,包括保留字、标识符、运算符、标点符号和常量等。词法分析是编译过程中的一个阶段,在语法分析前进行。也可以和语法分析结合在一起作为一遍,由语法分析程序调用词法分析程序来获得当前单词供语法分析使用。要求:通过词法分析器能够实现以下五种类型如单词等的识别。(1)关键字"begin","end","if",

2、"then","else","while","write","read"等,"do","call","const","char","until","procedure","repeat"等(2)运算符:"+","-","*","/","="等(3)界符:"{","}","[","]",";",",",".","(",")",":"等(4)标识符(5)常量四.操作要求首先建立一个或多个文档,此处新建了两个文档,例:07196133.txt文本文档和zhaoxiaodong.txt文本文档,以供选择,各文本文档中都输入有不同的内容,6运行程序,出现提示,

3、输入文本文档的名称,即可对文本文档中的内容进行分析,并把分析结果输出显示在屏幕上。五.算法设计#include#includeusingnamespacestd;#defineMAX22charch='';stringkey[15]={"begin","end","if","then","else","while","write","read","do","call","const","char","until","procedure","repeat"};intIskey(stringc){//关键字判断inti

4、;for(i=0;i='a'))

5、

6、((c<='Z')&&(c>='A')))return1;elsereturn0;}intIsDigit(charc){//判断是否为数字if(c>='0'&&c<='9')return1;elsereturn0;}voidanalyse(FILE*fpin){stringarr="";while((ch=fgetc(fpi

7、n))!=EOF){arr="";if(ch==''

8、

9、ch=='t'

10、

11、ch==''){}elseif(IsLetter(ch)){while(IsLetter(ch)

12、

13、IsDigit(ch)){if((ch<='Z')&&(ch>='A'))ch=ch+32;6arr=arr+ch;ch=fgetc(fpin);}fseek(fpin,-1L,SEEK_CUR);if(Iskey(arr)){cout<

14、igit(ch)){while(IsDigit(ch)

15、

16、ch=='.'&&IsDigit(fgetc(fpin))){arr=arr+ch;ch=fgetc(fpin);}fseek(fpin,-1L,SEEK_CUR);cout<

17、:case',':case'{':case'}':cout<':{ch=fgetc(fpin);if(ch=='=')cout<<">="<<"t$属于运算符"<')cout<<">>"<<"t

18、$属于输入控制符"<"<<"t$属于运算符"<

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

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

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