資源簡介
編譯原理語義分析器,實現分析部分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
評論
共有 條評論