欢迎来到天天文库
浏览记录
ID:55742578
大小:49.50 KB
页数:6页
时间:2020-06-04
《编译实验王秀敏实验报告,模块图.doc》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库。
1、N调用返回缓冲区扫描一个字符缓冲区主函数main()N输入文件名,判断能否打开文件Y缓冲区中是否还有字符Y结束取单词扫描一个字符调用返回输出模块设计实验报告:实验名称:词法分析实验目的和要求编制一个读单词过程,从输入的源程序中,识别出各个具有独立意义的单词,即基本保留字、标识符、常数、运算符、分隔符五大类。实验内容和步骤:一、实验内容对于这个实验,我总共用了四个函数,即主函数、扫描函数、建立缓冲区、取单词。主要完成的功能是从缓冲区中识别出一个个单词,并能够区分所取的单词是什么类型。二、实验步骤1、基于实验的内容,构造程序所需的模块2、根据已建构的模块,写出各
2、个模块的相应程序代码3、在主函数中调用模块来完成所要得到的效果在此,我想先介绍一下我的三个子模块,第一个是扫描函数。扫描函数scanner(),其实大家都比较熟悉了,就是我们上次实验内容,可以原封不动的拿来用。它的功能是调用一次就从缓冲区中取一个字符出来。这为我们的取字符提供了基础,因此如果这个程序不会设计的话,那么这个实验就没法设计了。至于建立第二个模块,就是从文件中把一个个字符读到缓冲区,比较简单,我在这里就不想说了。接下来,我想比较地说一下第三个模块,也就是本实验的主要要求。这个模块的函数程序代码如下:chargetsym()//从缓冲区中取一个单词{
3、boolflag=false;//用来表示取出的单词是否为关键词,如果是则flag的值为true,否则为falseintk=-1;//表示取出的字符放在单词数组的指针CType='0';//预先定义的取出的单词的类型Lasttype='0';//初始化先前的类型,此变量为判断正负数用while(ch<=32&&ch>0)//去掉不能显示的字符Fbuffer=scanner();if(ch>='a'&&ch<='z'
4、
5、ch>='A'&&ch<='Z')//取出标识符或者是关键词{k=-1;while(true)//取出的单词长度不超过WMaxlen,如果超过
6、,则其后的字符无效{if((++k)='a'&&ch<='z'
7、
8、ch>='A'&&ch<='Z'
9、
10、ch>='0'&&ch<='9'))break;}Word[++k]=' ';//以' '标识取出单词的结束,以方便后面的判断此单词是标识符还是关键词for(inti=0;i11、(Word,KEY[i])==0){flag=true;break;}if(flag)CType='1';//如果是关键词,则把此单词的类型定义为1型elseCType='2';//否则是标识符,其类型为2}elseif(ch>='0'&&ch<='9')//判断是不是为整数{Word[++k]=ch;Fbuffer=scanner();while(true)//如果是数字,则一直接受,且定义它的类型为3if(ch>='0'&&ch<='9'){Word[++k]=ch;Fbuffer=scanner();}else{CType='3';break;}//不12、是数字则跳出循环//如果以字母开头,且长度不超过WMaxlen,且下面跟有字母,则此整数非法,输出类型为8,在主程序中输出出错信息if(k='a'&&ch<='z'13、14、ch>='A'&&ch<='Z'){Word[++k]=ch;Fbuffer=scanner();//取这个非法整数的单词,其中可包含英文字母和数字while(ch>='a'&&ch<='z'15、16、ch>='A'&&ch<='Z'17、18、ch>='0'&&ch<='9'19、20、Fbuffer==-1)if(k21、anner();}else{Fbuffer=scanner();k++;}if(k>WMaxlen)//如果长度大于取出单词定义的最大长度,则返回类型为8,在主程序中打出出错信息CType=Longtype;elseCType=Errtype;//否则返回类型7,在主程序出错,并明确写出此单词的具体内容}Word[++k]=' ';}elseif(ch=='+'22、23、ch=='-'24、25、ch=='*'26、27、ch=='/')//取出是运算符号的单词{Word[++k]=ch;if(ch=='+'28、29、ch=='-')//如果是+号或者是-号,则还要判断是不是正负数i30、f(Lasttype=='6')//判断其取出的当前
11、(Word,KEY[i])==0){flag=true;break;}if(flag)CType='1';//如果是关键词,则把此单词的类型定义为1型elseCType='2';//否则是标识符,其类型为2}elseif(ch>='0'&&ch<='9')//判断是不是为整数{Word[++k]=ch;Fbuffer=scanner();while(true)//如果是数字,则一直接受,且定义它的类型为3if(ch>='0'&&ch<='9'){Word[++k]=ch;Fbuffer=scanner();}else{CType='3';break;}//不
12、是数字则跳出循环//如果以字母开头,且长度不超过WMaxlen,且下面跟有字母,则此整数非法,输出类型为8,在主程序中输出出错信息if(k='a'&&ch<='z'
13、
14、ch>='A'&&ch<='Z'){Word[++k]=ch;Fbuffer=scanner();//取这个非法整数的单词,其中可包含英文字母和数字while(ch>='a'&&ch<='z'
15、
16、ch>='A'&&ch<='Z'
17、
18、ch>='0'&&ch<='9'
19、
20、Fbuffer==-1)if(k21、anner();}else{Fbuffer=scanner();k++;}if(k>WMaxlen)//如果长度大于取出单词定义的最大长度,则返回类型为8,在主程序中打出出错信息CType=Longtype;elseCType=Errtype;//否则返回类型7,在主程序出错,并明确写出此单词的具体内容}Word[++k]=' ';}elseif(ch=='+'22、23、ch=='-'24、25、ch=='*'26、27、ch=='/')//取出是运算符号的单词{Word[++k]=ch;if(ch=='+'28、29、ch=='-')//如果是+号或者是-号,则还要判断是不是正负数i30、f(Lasttype=='6')//判断其取出的当前
21、anner();}else{Fbuffer=scanner();k++;}if(k>WMaxlen)//如果长度大于取出单词定义的最大长度,则返回类型为8,在主程序中打出出错信息CType=Longtype;elseCType=Errtype;//否则返回类型7,在主程序出错,并明确写出此单词的具体内容}Word[++k]=' ';}elseif(ch=='+'
22、
23、ch=='-'
24、
25、ch=='*'
26、
27、ch=='/')//取出是运算符号的单词{Word[++k]=ch;if(ch=='+'
28、
29、ch=='-')//如果是+号或者是-号,则还要判断是不是正负数i
30、f(Lasttype=='6')//判断其取出的当前
此文档下载收益归作者所有