• 大小: 11KB
    文件类型: .zip
    金币: 2
    下载: 1 次
    发布日期: 2021-07-02
  • 语言: C/C++
  • 标签: 编译原理  代码  

资源简介

编译原理语义分析器,实现分析部分C语言的语法成分,将其翻译成三地址代码。

资源截图

代码片段和文件信息

#include
#include
#include
#include
#define KEY_NUM 34
/*声明*/
void emit(char * resultchar *ag1char *opchar *ag2);
char * newtemp();
int lrparser();
int yucu();
int statement();
char * expression();
char * term();
char * factor();
struct 
{
char result[8];
char ag1[8];
char op[8];
char ag2[8];
}quad[20];
char prog[80]token[32]str[100];
char ch;
int synpindexconst_numkkrowktoutc;
FILE *fp_in*fp_out;
char *keyWord[KEY_NUM]={“auto““break““case““char““const“
“continue““default““do““double““else“
“enum““extern““float““for““goto“
“if““int““long““register““return“
“short““signed““sizeof““static““struct“
“switch““typedef““union““unsigned““void“
“volatile““while““begin““end“};
char *constant[100];
int constValue[100];

/*****************************************************
文件操作 
*****************************************************/
/*打开文件*/
void fileOpen(char fileInput[]char fileOuput[])
{
if((fp_in=fopen(fileInput“r“))==NULL)
{
printf(“打开读取文件失败!\n“);
return;
}
if((fp_out=fopen(fileOuput“w“))==NULL)
{
printf(“打开写入文件出错!\n“);
return;
}
}
/*关闭文件*/
void fileClose()
{
if(fp_in!=NULL)
fclose(fp_in);
if(fp_out!=NULL)
fclose(fp_out);
}
/*输出文件*/
void output(int achar tk[])
{
printf(“(%d%s)\n“atk);
fprintf(fp_out“(%d%s)\n“atk);
}
/*****************************************************
词法分析
*****************************************************/
/*错误处理*/
void error(char msg[])
{
printf(“%s\n“msg);
return;
}
/*读取一个字符*/
void getch()
{
ch=fgetc(fp_in);

/*读取空格*/
void getbc()
{
while(ch==‘ ‘ || ch==‘\r‘ || ch==‘\t‘ || ch==‘\n‘)
{
if(ch==‘\n‘)
{
row++;
}
getch();
}
}
/*读取回车*/
void geten()
{
while(ch==‘\r‘)
getch();
}
/*读取tab*/
void gettab()
{
while(ch==‘\t‘)
getch();
}
/*读取行*/
void getline()
{
while(ch==‘\n‘)
getch();
}
/*换行*/
void nextline()
{
while(ch!=‘\n‘)
getch();
}
/*连接字符串*/
void concat()
{
int len;
/*if(syn==35)
{
len=strlen(str);
str[len]=ch;
str[len+1]=‘\0‘;
}*/

len=strlen(token);
token[len]=ch;
token[len+1]=‘\0‘;
 
}
/*判断是否为字母*/
bool letter(char c)
{
if((c>=‘a‘&&c<=‘z‘)||(c>=‘A‘&&c<=‘Z‘))
return true;
if(c==‘_‘)
return true; 
return false;
}
/*判断是否数字*/
bool digit(char c)
{
if(c>=‘0‘&&c<=‘9‘)
return true;
return false;
}
/*判断是否关键字*/
int reserve()
{
int i;
for(i=0;i {
if(strcmp(tokenkeyWord[i])==0)
return (i+100);
}
return (10);
}
/*指针回退*/
void retract()
{
fseek(fp_in-1SEEK_CUR);
}

/*十进制转二进制*/

/*扫描*/
void scaner()
{
//printf(“%d\t%s\n“syntoken);
memset(token0sizeof(token));
memset(str0sizeof(str));
getch();
getbc();
if(letter(ch))
{
while(letter(ch)||digit(ch))
{
concat();
getch();
}
retract();
syn=reserve();

 属性            大小     日期    时间   名称
----------- ---------  ---------- -----  ----
     目录           0  2011-06-01 22:28  语义分析器\
     文件         101  2011-05-12 23:43  语义分析器\out.txt
     文件          48  2011-05-12 22:38  语义分析器\test.txt
     文件         129  2011-05-13 00:00  语义分析器\程序说明.txt
     文件        9894  2011-05-12 22:58  语义分析器\语义分析器.cpp
     文件       23925  2011-05-12 23:43  语义分析器\语义分析器.exe

评论

共有 条评论