您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 质量控制/管理 > 实验二、语法分析器(源代码)
语法分析实验报告一、实验目的:1.了解单词(内部编码)符号串中的短语句型结构形成规律。2.理解和掌握语法分析过程中语法分析思想(LL,LR)的智能算法化方法。二、实验内容:构造自己设计的小语言的语法分析器:1.小语言的语法描述(语法规则)的设计即文法的设计;2.把文法形式符号中所隐含的信息内容挖掘出来并用LL或LR的资料形式(分析表)表示出来;3.语法分析的数据输入形式和输出形式的确定;4.语法分析程序各个模块的设计与调试。主要设备和材料:电脑、winxp操作系统、VC语言系统三、实验步骤:1、语法规则①程序::={变量定义语句|赋值语句|条件语句|循环语句}②变量定义语句::=var变量{,变量};③赋值语句::=变量:=表达式;④表达式::=标识符{运算符标识符};⑤标识符::=变量|常量⑥运算符::=+|-|*|/|=|=⑦条件语句::=if语句[else语句]⑧if语句::=if(表达式)then[begin]{赋值语句|条件语句|循环语句}[end]⑨else语句::=[begin]{赋值语句|条件语句|循环语句}[end]⑩循环语句::=while(表达式)[begin]{赋值语句|条件语句|循环语句}[end]输出语句::=prn表达式--注1:若if语句、else语句、循环语句中出现begin,后面的end必须出现,即begin与end同对出现--注2:if、while后的(,)表示终结符,而不是定义成分优先的说明符号2、分析表::=变量常量,;运算符()变量定义-②-②-②-②赋值语句-③-③-③-③-③条-------件语句⑦⑦⑦⑦⑦⑦⑦循环语句-⑩-⑩-⑩-⑩-⑩-⑩-⑩输出语句---分析表(续):whilevarbeginendifthenprn变量定义-②赋值语句条件语句-⑦-⑦-⑦-⑦循环语句-⑩-⑩-⑩输出语句-3、调试和测试四、实验总结:本实验在词法分析的基础上,对提取出的标识符进行语法判断。对已有的语法规则运用LL(1)文法判别并进行构造分析表时,遇到的最大困难是:当发生规约冲突时,该如何处理。如对于产生式s--aAb,当对a进行规约时,满足语法规则的β(用户输入串中当前要进行规约的标识符)只有有限种,而不满足的却有无限种情况。当发生规约冲突时,如何在这无限种情况中,确定冲突的具体信息,以便用户查找。在反复的尝试和验证中,我们发现发生冲突的用户输入串满足一定的规律,且按这种规律可以把这无限种情况化归为有限类,于是我们找出其中规律并进行划分,然后再对这些有限类冲突进行处理。五、实验心得:通过这次实验有以下几点收获:1.LR(1)的构造使得对理论的知识理解的更加透彻。其中LR(1)分析表构造了很多遍,一直无法得到正确结果,这是恒心的考验。2.在写程序中用类数组来存放单词属性使得对单词各项值的调用更加方便,特别是对出错信息的检测有很大的作用。3.本实验是在词法基础上的更进一步,在词法程序上添加语法程序,更加理解二者之间的关系。词法分析为语法分析提供了词法单元,方便分析,使程序模块化,易于读懂。六、附录:#includeiostream#includefstream#includestring#includemath.h#includectype.h#includecstdlibusingnamespacestd;#defineMax655//最大代码长度#defineWordMaxNum256//变量最大个数#defineDigitNum256//常量最大个数#defineMaxKeyWord32//关键字数量#defineMaxOptANum8//运算符最大个数#defineMaxOptBNum4//运算符最大个数#defineMaxEndNum11//界符最大个数typedefstructDisplayTable{intIndex;//标识符所在表的下标inttype;//标识符的类型intline;//标识符所在表的行数charsymbol[20];//标识符所在表的名称}Table;intTableNum=0;//display表的表项总数charWord[WordMaxNum][20];//标识符表charDigit[WordMaxNum][20];//数字表intWordNum=0;//变量表的下标intDigNum=0;//常量表的下标boolerrorFlag=0;//错误标志intTableIndex=-1;//display表的下标索引intbeginCount=0;//遇到begin加1,遇到end减1intifCount=0;//遇到if加1Table*table=newTable[Max];//关键字constchar*constKeyWord[MaxKeyWord]={and,array,begin,case,char,constant,do,else,end,false,for,if,input,integer,not,of,or,output,packed,procedure,program,read,real,repeat,set,then,to,type,until,var,while,with,prn};//单目运算constcharOptA[]={'+','-','*','/','=','#','',''};//双目运算符constchar*OptB[]={=,=,:=,};//界符constcharEnd[]={'(',')',',',';','.','[',']',':','{','}',''};voiderror(charstr[20],intnLine,interrorType){errorFlag=1;cout\nError:;switch(errorType){case1:cout第nLine-1行str变量的长度超过限制!\n;break;case2:cout第nLine-1行str小数点错误!\n;break;case3:cout第nLine-1行str常量的长度超过限制!\n;break;}//switch}//errorvoidScanner(charch[],intchLen,intnLine){intchIndex=0;while(chIndexchLen)//对输入的字符扫描{/****************处理空格和tab***************************///忽略空格和tabwhile(ch[chIndex]==''||ch[chIndex]==9){chIndex++;}/*************************处理换行符*********************///遇到换行符,行数加1while(ch[chIndex]==10){nLine++;chIndex++;}/***************************标识符**********************/if(isalpha(ch[chIndex]))//以字母、下划线开头{charstr[256];intstrLen=0;//是字母、下划线while(isalpha(ch[chIndex])||ch[chIndex]=='_'){str[strLen++]=ch[chIndex];chIndex++;while(isdigit(ch[chIndex]))//不是第一位,可以为数字{str[strLen++]=ch[chIndex];chIndex++;}}str[strLen]=0;//字符串结束符if(strlen(str)20)//标识符超过规定长度,报错处理{error(str,nLine,1);}else{inti;for(i=0;iMaxKeyWord;i++)//与关键字匹配//是关键字,写入table表中if(strcmp(str,KeyWord[i])==0){strcpy(table[TableNum].symbol,str);table[TableNum].type=1;//关键字table[TableNum].line=nLine;table[TableNum].Index=i;TableNum++;break;}if(i=MaxKeyWord)//不是关键字{table[TableNum].Index=WordNum;strcpy(Word[WordNum++],str);table[TableNum].type=2;//变量标识符strcpy(table[TableNum].symbol,str);table[TableNum].line=nLine;TableNum++;}}}/**************************常数**************************/elseif(isdigit(ch[chIndex]))//遇到数字{intflag=0;charstr[256];intstrLen=0;//数字和小数点while(isdigit(ch[chIndex])||ch[chIndex]=='.'){//flag表记小数点的个数,0时为整数,1时为小数,2时出错if(ch[chIndex]=='.')flag++;str[strLen++]=ch[chIndex];chIndex++;}str[strLen]=0;if(strlen(str)20)//常量标识符超过规定长度20,报错处理{error(str,nLine,3);}if(flag==0){table[TableNum].type=3;//整数}if(flag==1){table[TableNum].type=4;//小数}if(flag1){error(str,nLine,2);}table[TableNum].Index=DigNum;strcpy(Digit[DigNum++],str);strcpy(table[TableNum].symbol,str);table[TableNum].line=nLine;TableNum++;}/*************************运算符************************/else{//用来区分是不是无法识别的标识符,0为运算符,1为界符interrorFlag;charstr[3];str[0]=ch[chIndex];str[1]=ch[chIndex+1];str[2]='\0';inti;for(i=0;iMaxOptBNum;i++)//MaxOptBNum)if(strcmp(str,OptB[i])==0){errorFlag=0;table[TableNum].type=6;strcpy(table[TableNum].symbol,str);table[TableNum].line=nLine;table[TableNum].Index=i;TableNum++;chIndex=chIndex+2;break;}if(i=MaxOptBNum){for(intk=0;kMaxOptANum;k++)if(OptA[k]==ch[chIndex]){errorFlag=0;table[TableNum].type=5;table[TableNum].symbol[0]=ch[chIndex];table[TableNum].symbol[1]=0;table[TableNum].line=nLine;table[TableNum].Index=k;TableNum++;chIndex++;break;}/*****************
本文标题:实验二、语法分析器(源代码)
链接地址:https://www.777doc.com/doc-7283892 .html