资源简介

华南农业大学 编译原理 综合性实验报告 选择部分C语言的语法成分,设计其词法分析程序、语法语义分析程序。

资源截图

代码片段和文件信息

#include 
#include 
#include   

#define BUFFSIZE 5000
char prog[BUFFSIZE]token[8];
char chch1;
int synpqmnsumi=1k=0kkflag=0;
char *rwtab[32]={“main““break““case““char““define““continue““default“
                 “do““double““else““what““extern““float““for““goto““if“
                 “int““long““stack““return““short““fopen““sizeof“
 “static““struct““switch““typedef““enum““unsigned““void““fclose““while“};

int main()  /*主函数*/
{
  void scaner();
  int lrparser();
  FILE *fp;
  if((fp=fopen(“test.txt““r“))==NULL)
    { printf(“无法打开文件!\n“);
      exit(1);
    }
  p=0;
  while(!feof(fp))
    {  prog[p++]=fgetc(fp);
       if(p>=5000)
       {  printf(“缓冲区容量不够!\n“);
          exit(1);
           }
    }/*把文件test中的内容存入数组prog中*/
  fclose(fp);
  printf(“%s\n“prog);
  p=0;
printf(“输出词法分析结果:\n“);
do
{
scaner();
switch(syn)
{
case 34:printf(“(%d%d)“synsum);break;
case -1:printf(“error“);break;
default:printf(“(%d%s)“syntoken);
}
}while(syn!=0);
p=0;
printf(“\n语法语义的分析开始:\n“);
  scaner();
  lrparser(); 
  system(“pause“); 
  return 0; 
}

void scaner()

  for(n=0;n<8;n++) token[n]=NULL;
  m=0;
  sum=0;
  ch=prog[p];
  while(ch==‘ ‘||ch==‘\n‘)
  { p++;
    ch=prog[p];
      }/*读下一个字符*/

  if((ch>=‘A‘&&ch<=‘Z‘)||(ch>=‘a‘&&ch<=‘z‘))
  { while((ch>=‘A‘&&ch<=‘Z‘)||(ch>=‘a‘&&ch<=‘z‘)||(ch>=‘0‘&&ch<=‘9‘))
    { token[m]=ch;
      m++;p++;
      ch=prog[p];
        }

  token[m++]=‘\0‘;
  syn=33;
  for(n=0;n<32;n++)
     if(strcmp(tokenrwtab[n])==0)
     { syn=n+1;
       break;
         }
  }/*判断输入字符是否为标识符或者关键字的情况*/

  else
      if(ch>=‘0‘&&ch<=‘9‘)
      { while(ch>=‘0‘&&ch<=‘9‘)
        { sum=sum*10+ch-‘0‘;
          p++;
          ch=prog[p];
            }
        syn=34;
    }/*判断输入字符是否为整型常数的情况*/

  else
      switch(ch)
      {
       case ‘<‘:token[m]=ch;
                p++;
                ch=prog[p];
                if(ch==‘>‘)
                { syn=42;
                  m++;
                  token[m]=ch;
                  p++;
                }/*出现<>的情况*/
                else if(ch==‘=‘)
                { syn=43;
                  m++;
                  token[m]=ch;
                  p++;
                }/*出现<=的情况*/
                else
                { syn=41;}
                break;

       case ‘>‘:token[m]=ch;
                p++;
                ch=prog[p];
                if(ch==‘=‘)
                { syn=45;
                  m++;
                  token[m]=ch;
                  p++;
                }/*出现>=的情况*/
                else
                {syn=44;}
                break;

       case ‘:‘:token[m]=ch;
                p++;
                ch=prog[p];
                if(ch==‘=‘)
                { syn=40;
                  m++;
                  token[m]=ch;
                  p++;
                }/*出现:=的

 属性            大小     日期    时间   名称
----------- ---------  ---------- -----  ----

     文件         60  2012-12-03 13:05  201031000121  伍伟劲\right-test.txt

     文件         60  2012-12-03 13:51  201031000121  伍伟劲\test.txt

     文件         59  2012-12-03 13:18  201031000121  伍伟劲\wrong-test.txt

     文件        277  2012-12-03 13:31  201031000121  伍伟劲\程序运行说明.txt

     文件       7661  2012-12-03 13:33  201031000121  伍伟劲\编译原理.cpp

     文件     257536  2012-12-03 13:44  201031000121  伍伟劲\编译原理—伍伟劲.doc

     目录          0  2012-12-03 13:51  201031000121  伍伟劲

----------- ---------  ---------- -----  ----

               265653                    7


评论

共有 条评论