标签:
实验一、词法分析实验
商业软件工程专业 陈若倩 201506110135
一、 实验目的
通过设计一个词法分析程序,对词法进行分析,加强对词法的理解,掌握对程序设计语言的分解和理解。
二、 实验内容和要求
在原程序中输入源代码
在源程序中,自动识别单词,把单词分为五种,并输出对应的单词种别码。
各种单词符号对应的种别码。
输出形式:
– (单词种别,单词自身的值)
– 整数码
– 标识符token、常数sum
– 关键字、运算符、界符token
一、 实验方法、步骤及结果测试
可执行程序名:编译原理 实验报告.exe
实现主要功能的程序段,重要的是程序的注释解释。
#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <ctype.h>
void cffx();
char prog[80]={‘\0‘},
token[8];
char ch;
int syn,n,sum,m,p;
char
*rwtab[6]={"begin","if","then","while","do","end"};
main()
{
p=0;
printf("\nplease input string:\n");
do {
ch=getchar();
prog[p++]=ch;
}while(ch!=‘#‘);
p=0;
do{
cffx();
switch(syn){
case 11: printf("(%d,%d)\n",syn,sum);break;
case -1: printf("\n ERROR;\n");break;
default: printf("(%d,%s)\n",syn,token);
}
}while(syn!=0);
getch();
}
void cffx()
{
m=0;
sum=0;
for(n=0;n<8;n++)
token[n]=‘\0‘;
ch=prog[p++];
while(ch==‘ ‘)
ch=prog[p++];
if(isalpha(ch))
{
while(isalpha(ch)||isdigit(ch))
{
token[m++]=ch;
ch=prog[p++];}
token[m++]=‘\0‘;
ch=prog[p--];
syn=10;
for(n=0;n<6;n++)
if(strcmp(token,rwtab[n])==0)
{
syn=n+1;
break;}}
else
if(isdigit(ch))
{
while(isdigit(ch))
{
sum=sum*10+ch-‘0‘;
ch=prog[p++];}
ch=prog[p--];
syn=11;}
else
switch(ch){
case‘<‘:m=0;token[m++]=ch;ch=prog[p++];
if(ch==‘>‘){
syn=21;
token[m++]=ch;}
else if(ch==‘=‘){
syn=22;
token[m++]=ch;}
else{
syn=20;
ch=prog[p--];}
break;
case‘>‘:m=0;token[m++]=ch;ch=prog[p++];
if(ch==‘=‘){
syn=24;
token[m++]=ch;}
else{
syn=23;
ch=prog[p--];}
break;
case‘:‘:m=0;token[m++]=ch;ch=prog[p++];
if(ch==‘=‘){
syn=18;
token[m++]=ch;}
else{
syn=17;
ch=prog[p--];}
break;
case‘+‘:syn=13;
token[0]=ch;
break;
case‘-‘:syn=14;
token[0]=ch;
break;
case‘*‘:syn=15;
token[0]=ch;
break;
case‘/‘:syn=16;
token[0]=ch;
break;
case‘=‘:syn=25;
token[0]=ch;
break;
case‘;‘:syn=26;
token[0]=ch;
break;
case‘(‘:syn=27;
token[0]=ch;
break;
case‘)‘:syn=28;
token[0]=ch;
break;
case‘#‘:syn=0;
token[0]=ch;
break;
default:syn=-1;
}
}
一、 实验总结
学会编写一个简单的词法分析程序,虽然在过程中有许多艰难。但是最终制作成功的喜悦,就好像在上课终于学会怎么推导出结果一样激动不已。
标签:
原文地址:http://www.cnblogs.com/severusandsusa/p/5960802.html