- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
【实验目的】
熟悉词法分析的基本原理,词法分析的过程以及词法分析屮要注意的问题。
复习高级语言,进一步加强用高级语言来解决实际问题的能力。
通过完成词法分析程序,了解词法分析的过程。
【实验内容】
用C语言编写一个PL/O词法分析器,为语法语义分析提供单词,使之能把输入的字符串形 式的源程序分割成一个个单词符号传递给语法语义分析,并把分析结果(基本字,运算符, 标识符,常数以及界符)输出。
【实验步骤和要求】
?词法分析过程的流程图
?每个模块的源代码
〃对关键字等实现初始化 void init()
{ int i;
for(i=0;i=255;i++){ ssym[i]=nul;)
ssym[+‘]二 plus;
ssym[-f]-minus; ssym严]-times; ssym[7‘] 一 slash;
ssym[,(/]=lparen; ssym[T]=pe「iod;
ssym[)‘]二rparen; ssym[-*]=eql; ssym[T]二comma;
ssym|/#】=neq; ssyml^^semicolon;
strcpy((word[01f01)/,beginH); strcpy((word [2] [0]),const);
strcpy((word [4][0] ),end); strcpy((word [6][0]),Hodd);
strcpy((word ⑻[0]),read”); strcpy((word [ 10] [0]), ” var“);
strcpy((woni[12][0]),”wrilc”);
strcpy((word[l][0]);,calF,);
strcpy((word[3][0]),udoM);
strcpy((word ⑸[0]
strcpy((wordl7][0J),procedure);
strcpy((word[9][0]), program”);
strcpy((word] 11 ][()]),“ while);
strcpy((word] 13][0]),”lhc】T);
wsym[2J=constsym; wsym[5]=ifsym; wsym[8]=readsym; wsym[l l]=whilesym;wsym[0J=beginsym; wsym[l ]=callsym; wsym[3]=dosym; wsym[4]=endsym;
wsym[2J=constsym; wsym[5]=ifsym; wsym[8]=readsym; wsym[l l]=whilesym;
wsym[6]=oddsym; wsymf7]=procsym;
wsym[9]=programsym; wsym[ 10]=varsym; wsym[ 12]=writesym; wsym[ 13]=thensym;
〃读取源文件并判断单词类别
void getsym()
{ long m;
char id[al+l],a[al+l];
int i,k,n=0;
init();
if(ch==, l|ch== 10||ch==9){ch=fgetc(fin);} 〃去除空格、制表符、换行符
else{
if(ch=,a,ch=,z,||ch=,A,ch=,Z,){ 〃判断是否保留字
k=0;
do{
if(kal){
a[k]=ch;
k++;}
ch=fgetc(fi n);
} while (ch=*ach=,z,||ch=,0chv=9||ch=Ach=,Z,);
afk]=O;
strcpy(id,a);
for(i=0;inorw;i++) {
if(strcmp(id,word[i])==0) {
sym=wsym[i];
n=l;
if(i==7){
printf(H%s\t\t%ssym(保留字)\n”,id,id);
fprintf(fout,%s\t\t%ssym(保留字)\n”,id,id);}
else}
printf(%s\t\t\t%ssym(保留字)\n,id,id); fprintf(fout,%s\t\t\t%ssym(保留字)\n,id,id);} break;}
}
if(n==O) {
sym=ident;
printf( %s\t\t\tident(标识符)\n,id); fprintf(fout,%s\t\t\tident(标识符)\n”,id);
}
}
else{
if(ch=,0?chv=9)
{ k=0;
m=0;
sym 二 number;
do{
m=10*m+ch-0,;
k++; ch=getc(fin);
} while(ch=*0 ch=,9,); if(k=nmax)( printf(\t ERROR!数值太大!\n”);
原创力文档


文档评论(0)