欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    编译原理词法分析和语法分析报告+代码(C语言版)(共18页).doc

    • 资源ID:6770491       资源大小:111KB        全文页数:23页
    • 资源格式: DOC        下载积分:20金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要20金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    编译原理词法分析和语法分析报告+代码(C语言版)(共18页).doc

    精选优质文档-倾情为你奉上 词法分析一、 实验目的设计、编制并调试一个词法分析程序,加深对词法分析原理的理解。二、 实验要求2.1 待分析的简单的词法(1)关键字: begin if then while do end所有的关键字都是小写。(2)运算符和界符: = + - * / < <= <> > >= = ; ( ) #(3)其他单词是标识符(ID)和整型常数(SUM),通过以下正规式定义:ID = letter (letter | digit)*NUM = digit digit*(4)空格有空白、制表符和换行符组成。空格一般用来分隔ID、SUM、运算符、界符和关键字,词法分析阶段通常被忽略。2.2 各种单词符号对应的种别码:表2.1 各种单词符号对应的种别码单词符号种别码 单词符号种别码bgin1:17If2:=18Then3<20wile4<>21do5<=22end6>23lettet(letter|digit)*10>=24dight dight*11=25+13;2614(27*15)28/16#02.3 词法分析程序的功能:输入:所给文法的源程序字符串。输出:二元组(syn,token或sum)构成的序列。其中:syn为单词种别码; token为存放的单词自身字符串; sum为整型常数。例如:对源程序begin x:=9: if x>9 then x:=2*x+1/3; end #的源文件,经过词法分析后输出如下序列:(1,begin)(10,x)(18,:=)(11,9)(26,;)(2,if)三、词法分析程序的算法思想:算法的基本任务是从字符串表示的源程序中识别出具有独立意义的单词符号,其基本思想是根据扫描到单词符号的第一个字符的种类,拼出相应的单词符号。3.1 主程序示意图:主程序示意图如图3-1所示。其中初始包括以下两个方面: 关键字表的初值。关键字作为特殊标识符处理,把它们预先安排在一张表格中(称为关键字表),当扫描程序识别出标识符时,查关键字表。如能查到匹配的单词,则该单词为关键字,否则为一般标识符。关键字表为一个字符串数组,其描述如下:Char *rwtab6 = “begin”, “if”, “then”, “while”, “do”, “end”,;置初值调用扫描子程序输出单词二元组输入串结束 否 是结束 图3-1(2)程序中需要用到的主要变量为syn,token和sum3.2 扫描子程序的算法思想:首先设置3个变量:token用来存放构成单词符号的字符串;sum用来整型单词;syn用来存放单词符号的种别码。扫描子程序主要部分流程如图3-2所示。变量初始化忽略空格是否文件结束? 返回 是 是否字母拼字符串 数字 其他运算符、 符号界符等符号是否关键字?返回拼数 否对不同符号给出相应的syn值报错syn=10 是syn=1111syn为对应关键字的单词种别码图 3-2四、词法分析程序的C语言程序源代码:#include <stdio.h>#include <string.h>char prog80,token8,ch;int syn,p,m,n,sum;char *rwtab6="begin","if","then","while","do","end" scaner();main()p=0; printf("n please input a string(end with '#'):/n"); do scanf("%c",&ch); progp+=ch; while(ch!='#'); p=0; do scaner(); switch(syn) case 11:printf("( %-10d%5d )n",sum,syn); break; case -1:printf("you have input a wrong stringn"); getch(); exit(0); default: printf("( %-10s%5d )n",token,syn); break; while(syn!=0); getch(); scaner() sum=0; for(m=0;m<8;m+)tokenm+=NULL; ch=progp+; m=0; while(ch=' ')|(ch='n')ch=progp+; if(ch<='z')&&(ch>='a')|(ch<='Z')&&(ch>='A') while(ch<='z')&&(ch>='a')|(ch<='Z')&&(ch>='A')|(ch>='0')&&(ch<='9') tokenm+=ch; ch=progp+; p-; syn=10; for(n=0;n<6;n+) if(strcmp(token,rwtabn)=0) syn=n+1; break; else if(ch>='0')&&(ch<='9') while(ch>='0')&&(ch<='9') sum=sum*10+ch-'0' ch=progp+; p-; syn=11; else switch(ch) case '<':tokenm+=ch; ch=progp+; if(ch='=') syn=22; tokenm+=ch; else syn=20; p-; break; case '>':tokenm+=ch; ch=progp+; if(ch='=') syn=24; tokenm+=ch; else syn=23; p-; break; case '+': tokenm+=ch; ch=progp+; if(ch='+') syn=17; tokenm+=ch; else syn=13; p-; break; case '-':tokenm+=ch; ch=progp+; if(ch='-') syn=29; tokenm+=ch; else syn=14; p-; break; case '!':ch=progp+; if(ch='=') syn=21; tokenm+=ch; else syn=31; p-; break; case '=':tokenm+=ch; ch=progp+; if(ch='=') syn=25; tokenm+=ch; else syn=18; p-; break; case '*': syn=15; tokenm+=ch; break; case '/': syn=16; tokenm+=ch; break; case '(': syn=27; tokenm+=ch; break; case ')': syn=28; tokenm+=ch; break; case '': syn=5; tokenm+=ch; break; case '': syn=6; tokenm+=ch; break; case '': syn=26; tokenm+=ch; break; case '"': syn=30; tokenm+=ch; break; case '#': syn=0; tokenm+=ch; break; case ':':syn=17; tokenm+=ch; break; default: syn=-1; break; tokenm+='0' 五、结果分析:输入begin x:=9: if x>9 then x:=2*x+1/3; end # 后经词法分析输出如下序列:(begin 1)(x 10)(:17)(= 18)(9 11)(;26)(if 2) 如图5-1所示: 图5-1六、总结:词法分析的基本任务是从字符串表示的源程序中识别出具有独立意义的单词符号,其基本思想是根据扫描到单词符号的第一个字符的种类,拼出相应的单词符号。通过本试验的完成,更加加深了对词法分析原理的理解。 语法分析一、 实验目的编制一个递归下降分析程序,实现对词法分析程序所提供的单词序列的语法检查和结构分析。二、 实验要求利用C语言编制递归下降分析程序,并对简单语言进行语法分析。2.1 待分析的简单语言的语法用扩充的BNF表示如下:<程序>:=begin<语句串>end<语句串>:=<语句>;<语句><语句>:=<赋值语句><赋值语句>:=ID:=<表达式><表达式>:=<项>+<项> | -<项><项>:=<因子>*<因子> | /<因子><因子>:=ID | NUM | (<表达式>)2.2 实验要求说明输入单词串,以“#”结束,如果是文法正确的句子,则输出成功信息,打印“success”,否则输出“error”。例如: 输入 begin a:=9; x:=2*3; b:=a+x end # 输出 success! 输入 x:=a+b*c end # 输出 error2.3 语法分析程序的酸法思想(1)主程序示意图如图2-1所示。置初值调用scaner读下一个单词符号调用lrparser结束图2-1 语法分析主程序示意图(2)递归下降分析程序示意图如图2-2所示。(3)语句串分析过程示意图如图2-3所示。 是否begin?调用statement函数否是是否 ;?调用scaner否调用语句串分析程序是 调用scaner是否end? 否调用statement函数是调用scaner出错处理syn=0&&kk=0?否 图2-3 语句串分析示意图 是 打印分析成功出错处理 图2-2 递归下降分析程序示意图 (4)statement语句分析程序流程如图2-4、2-5、2-6、2-7所示。调用term函数是否标识符?否调用expression函数调用scaner是否:=?调用scaner是否+ , -?否否是调用scaner调用term函数出错处理出错处理图2-4 statement语句分析函数示意图 图2-5 expression表达式分析函数示意图调用scaner调用factor函数出错处理是否* , /?调用factor函数是否标识符?是否否是否整常数?是是否是否(?否是调用scaner是否)?调用expression函数图 2-6 term分析函数示意图否出错处理调用scaner调用scaner是图2-7 factor分析过程示意图三、 语法分析程序的C语言程序源代码:#include "stdio.h"#include "string.h"char prog100,token8,ch;char *rwtab6="begin","if","then","while","do","end"int syn,p,m,n,sum;int kk;factor();expression();yucu();term();statement();lrparser();scaner();main() p=kk=0; printf("nplease input a string (end with '#'): n"); do   scanf("%c",&ch);     progp+=ch;   while(ch!='#'); p=0; scaner(); lrparser(); getch();lrparser() if(syn=1)   scaner(); /*读下一个单词符号*/     yucu(); /*调用yucu()函数;*/     if (syn=6)       scaner();  if (syn=0)&&(kk=0) printf("success!n");      else if(kk!=1) printf("the string haven't got a 'end'!n");     kk=1;        else printf("haven't got a 'begin'!n"); kk=1;        return;yucu() statement(); /*调用函数statement();*/  while(syn=26)   scaner(); /*读下一个单词符号*/    if(syn!=6) statement(); /*调用函数statement();*/     return;statement() if(syn=10)   scaner(); /*读下一个单词符号*/     if(syn=18)       scaner(); /*读下一个单词符号*/  expression(); /*调用函数statement();*/            else printf("the sing ':=' is wrong!n");     kk=1;         else printf("wrong sentence!n");  kk=1;         return;expression() term();  while(syn=13)|(syn=14)    scaner(); /*读下一个单词符号*/      term(); /*调用函数term();*/      return;term() factor();  while(syn=15)|(syn=16)    scaner(); /*读下一个单词符号*/      factor(); /*调用函数factor(); */      return;factor() if(syn=10)|(syn=11) scaner();  else if(syn=27)    scaner(); /*读下一个单词符号*/      expression(); /*调用函数statement();*/      if(syn=28) scaner(); /*读下一个单词符号*/      else printf("the error on '('n");      kk=1;           else printf("the expression error!n");  kk=1;         return; scaner()   sum=0;    for(m=0;m<8;m+)tokenm+=NULL;    m=0;    ch=progp+;    while(ch=' ')ch=progp+;    if(ch<='z')&&(ch>='a')|(ch<='Z')&&(ch>='A')      while(ch<='z')&&(ch>='a')|(ch<='Z')&&(ch>='A')|(ch>='0')&&(ch<='9')   tokenm+=ch;    ch=progp+;         p-;      syn=10;      tokenm+='0'      for(n=0;n<6;n+) if(strcmp(token,rwtabn)=0)    syn=n+1;      break;              else if(ch>='0')&&(ch<='9')      while(ch>='0')&&(ch<='9')  sum=sum*10+ch-'0'   ch=progp+;  p-; syn=11;          else switch(ch)       case '<':m=0;    ch=progp+;    if(ch='>')        syn=21;          else if(ch='=')        syn=22;          else        syn=20;         p-;          break;  case '>':m=0;    ch=progp+;    if(ch='=')      syn=24;          else      syn=23;        p-;          break;  case ':':m=0;    ch=progp+;    if(ch='=')      syn=18;          else      syn=17;        p-;          break;  case '+': syn=13; break;  case '-': syn=14; break;  case '*': syn=15;break;  case '/': syn=16;break;  case '(': syn=27;break;  case ')': syn=28;break;  case '=': syn=25;break;  case '': syn=26;break;  case '#': syn=0;break; default: syn=-1;break;           四、 结果分析:输入 begin a:=9; x:=2*3; b:=a+x end # 后输出success! 如图4-1所示:图4-1输入 x:=a+b*c end # 后输出 error 如图4-2所示:图4-2五、 总结:通过本次试验,了解了语法分析的运行过程,主程序大致流程为:“置初值”à调用scaner函数读下一个单词符号à调用IrParseà结束。递归下降分析的大致流程为:“先判断是否为begin”à不是则“出错处理”,若是则“调用scaner函数”à调用语句串分析函数à“判断是否为end”à不是则“出错处理”,若是则调用scaner函数à“判断syn=0&&kk=0是否成立”成立则说明分析成功打印出来。不成立则“出错处理”。语义分析程序#include "stdio.h"#include "string.h"char prog100,token8,ch;char *rwtab6="begin","if","then","while","do","end"int syn,p,m,n,sum,q;int kk;struct char result18;    char ag118;    char op18;    char ag218;  quad20;char *factor();char *expression();int yucu();char *term();int statement();int lrparser();char *newtemp();scaner();emit(char *result,char *ag1,char *op,char *ag2);main() int j; q=p=kk=0; printf("nplease input a string (end with '#'): "); do   scanf("%c",&ch);     progp+=ch;   while(ch!='#'); p=0; scaner(); lrparser();if(q>19)printf(" to long sentense!n");else for (j=0;j<q;j+)printf("   %s = %s %s %s nn",quadj.result1,quadj.ag11,quadj.op1,quadj.ag21);getch();int lrparser()  int schain=0;    kk=0;    if (syn=1)      scaner(); schain=yucu(); if(syn=6)  scaner();    if(syn=0)&&(kk=0)  printf("Success!n");   else if(kk!=1)printf("short of 'end' !n");        kk=1;        getch();        exit(0);                else printf("short of 'begin' !n");    kk=1;    getch();    exit(0);      return (schain);int yucu() int schain=0;  schain=statement();  while(syn=26)   scaner();     schain=statement();     return (schain);int statement() char tt8,eplace8;  int schain=0;  if (syn=10)   strcpy(tt,token);     scaner();     if(syn=18)       scaner();  strcpy(eplace,expression();  emit(tt,eplace,"","");  schain=0;      else printf("short of sign ':=' !n");     kk=1;     getch();     exit(0);        return (schain);   char *expression() char *tp,*ep2,*eplace,*tt;  tp=(char *)malloc(12);  ep2=(char *)malloc(12);  eplace=(char *)malloc(12);  tt=(char *)malloc(12);  strcpy(eplace,term();  while(syn=13)|(syn=14)   if (syn=13)strcpy(tt,"+");     else strcpy(tt,"-");     scaner();     strcpy(ep2,term();     strcpy(tp,newtemp();     emit(tp,eplace,tt,ep2);     strcpy(eplace,tp);     return (eplace);char *term() char *tp,*ep2,*eplace,*tt;  tp=(char *)malloc(12);  ep2=(char *)malloc(12);  eplace=(char *)malloc(12);  tt=(char *)malloc(12);  strcpy(eplace,factor();  while(syn=15)|(syn=16)   if (syn=15)strcpy(tt,"*");     else strcpy(tt,"/");     scaner();     strcpy(ep2,factor();     strcpy(tp,newtemp();     emit(tp,eplace,tt,ep2);     strcpy(eplace,tp);     return (eplace);char *factor() char *fplace;  fplace=(char *)malloc(12);  strcpy(fplace,"");  if(syn=10)   strcpy(fplace,token);     scaner();     else if(syn=11)   itoa(sum,fplace,10);     scaner();     else if(syn=27)   scaner();     fplace=expression();     if(syn=28) scaner();     else printf("error on ')' !n");     kk=1;     getch();     exit(0);        else printf("error on '(' !n");  kk=1;  getch();  exit(0);         return (fplace);char *newtemp() char *p;  char m8;  p=(char *)malloc(8);  kk+;  itoa(kk,m,10);  strcpy(p+1,m);  p0='t'  return(p);  scaner()   sum=0;    for(m=0;m<8;m+)tokenm+=NULL;    m=0;    ch=progp+;    while(ch=' ')ch=progp+;    if(ch<='z')&&(ch>='a')|(ch<='Z')&&(ch>='A')      while(ch<='z')&&(ch>='a')|(ch<='Z')&&(ch>='A')|(ch>='0')&&(ch<='9')   tokenm+=ch;    ch=progp+;         p-;      syn=10;      tokenm+='0'      for(n=0;n<6;n+) if(strcmp(token,rwtabn)=0)    syn=n+1;      break;              else if(ch>='0')&&(ch<='9')      while(ch>='0')&&(ch<='9')  sum=sum*10+ch-'0'   ch=progp+;  p-; syn=11;          else switch(ch)       case '<':m=0;    ch=progp+;    if(ch='>')        syn=21;          else if(ch='=')        syn=22;          else        syn=20;         p-;          break;  case '>':m=0;    ch=progp+;    if(ch='=')      syn=24;          else      syn=23;        p-;          break;  case ':':m=0;    ch=progp+;    if(ch='=')      syn=18;          else      syn=17;        p-;          break;  case '+': syn=13; break;  case '-': syn=14; break;  case '*': syn=15;break;  case '/': syn=16;break;  case '(': syn=27;break;  case ')':

    注意事项

    本文(编译原理词法分析和语法分析报告+代码(C语言版)(共18页).doc)为本站会员(飞****2)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开