课程设计(论文)_语法分析器的实现.docVIP

  • 7
  • 0
  • 约1.65万字
  • 约 31页
  • 2016-12-04 发布于贵州
  • 举报
课程设计(论文)_语法分析器的实现

目录 1.语法分析方法 1 1.1 实验内容 1 1.2 语法分析器的实现 2 1.3 语法分析的程序流程图 2 2.程序设计 3 2.1 总体设计 3 2.2 子程序设计 8 3.程序中的结构说明 10 3.1 重要函数介绍及函数代码 10 4.程序测试 29 4.1 程序测试截图: 29 5 实验总结 31 1.语法分析方法 1.1 实验内容 语法分析程序用LL(1)语法分析方法。首先输入定义好的文法书写文件(所用的文法可以用LL(1)分析),先求出所输入的文法的每个非终结符是否能推出空,再分别计算非终结符号的FIRST集合,每个非终结符号的FOLLOW集合,以及每个规则的SELECT集合,并判断任意一个非终结符号的任意两个规则的SELECT集的交集是不是都为空,如果是,则输入文法符合LL(1)文法,可以进行分析。 题目: 已知文法G[S]: S→MH|a H→LSo|ε K→dML|ε L→eHf M→K|bLM 判断G 是否是LL(1)文法。 解:文法展开为: 0) S→M H 1) S→a 2) H→L S o 3) H→ε 4) K→d M L 5) K→ε 6) L→e H f 7) M→K 8) M→b L M 非终结符 FIRST 集 FOLLOW 集 S {a,d,b,ε,e} {#,o} M {d,ε,b}. {e,#,o} H {ε,e} . {#,f,o}.... L {e}.... {a,d,b,e,o,#} K {d,ε}.. {e,#,o}... 对相同左部的产生式可知: SELECT(S→M H)∩SELECT(S→a) ={ d,b ,e,#,o }∩ { a }=空集 SELECT(H→L S o)∩SELECT(H→ε) ={ e }∩ { #,f,o }=空集 SELECT(K→d M L)∩SELECT(K→ε) ={ d }∩ { e,#,o }=空集 SELECT(M→K)∩SELECT(M→b L M) ={ d,e,#,o }∩ { b }=空集 所以文法是LL(1)的。 1.2 语法分析器的实现 语法分析是编译过程的核心部分,它的主要任务是按照程序的语法规则,从由词法分析输出的源程序符号串中识别出各类语法成分,同时进行词法检查,为语义分析和代码生成作准备。这里采用自顶向下的LL(1)分析方法。 该程序可分为如下几步: (1)读入文法 (2)判断正误 (3)若无误,判断是否为LL(1)文法 (4)若是,构造分析表; (5)由句型判别算法判断输入符号串是为该文法的句型。 1.3 语法分析的程序流程图 2.程序设计 2.1 总体设计 2.1.1 求能推出空的非终结符集 Ⅰ、实例中求直接推出空的empty集的算法描述如下: void emp(char c){ 参数c为空符号 char temp[10];定义临时数组 int i; for(i=0;i=count-1;i++)从文法的第一个产生式开始查找 { if 产生式右部第一个符号是空符号并且右部长度为1, then将该条产生式左部符号保存在临时数组temp中 将临时数组中的元素合并到记录可推出符号的数组empty中。 } Ⅱ、求某一符号能否推出 int _emp(char c) { //若能推出,返回1;否则,返回0 int i,j,k,result=1,mark=0; char temp[20]; temp[0]=c; temp[1]=\0; 存放到一个临时数组empt里,标识此字符已查找其是否可推出空字 如果c在可直接推出空字的empty[]中,返回1 for(i=0;;i++) { if(i==count) return(0); 找一个左部为c的产生式 j=strlen(right[i]); //j为c所在产生式右部的长度if 右部长度为1且右部第一个字符在empty[]中. then返回1(A-B,B可推出空) if 右部长度为1但第一个字符为终结符,then 返回0(A-a,a为终结符) else { for(k=0;k=j-1;k++) { 查找临时数组empt[].并标记mark-=1(A-AB) if 找到的字符与当前字符相同(A-AB) 结束本次循环 else(mark等于0) 查找右部符号是否可推出空字,把返回值赋给result 把当前符号加入到临时数组empt[]里. } if 当前字符

您可能关注的文档

文档评论(0)

1亿VIP精品文档

相关文档