201506110111-陈泽翔-实验一报告

一、        实验目的

(1)    理解词法分析在编译程序中的作用。

(2)    加深对有穷自动机模型的理解。

(3)    掌握词法分析程序的实现方法。

(4)    用C语言对一个简单语言的子集编制一个一遍扫锚的编译理解,掌握编译程序的实现方法和技术。

二、        实验内容和要求

1,待分析的简单语言的词法

2,各种单词符号对应的种别码。

3,词法分析程序的功能(输入,输出)。

三、        实验方法、步骤及结果测试

1.      源程序名:压缩包文件(rarzip)中源程序名:CIFENXI.c

可执行程序名:CIFAFEN.exe

2.      原理分析及流程图

主要总体设计问题。

(包括存储结构,主要算法,关键函数的实现等)

词法分析主程序示意图

主要算法:

1.先应用数组存放关键字。

2.利用if,switch进行分析单词符号。

3.最后输出单词对应的种别码。

关键函数的实现:

1.*定义I/O库所用的某些宏和变量*/
2. /*定义字符串库函数*/
3./*提供有关屏幕窗口操作函数*/
4./*分类函数*/

  1. 3.      主要程序段及其解释:

实现主要功能的程序段,重要的是程序的注释解释。

主要程序共分为三大块,分别是标示符、数字、符号。

void scaner(){
m=0;
sum=0;
for(n=0;n<8;n++)
token[n]=‘\0‘;
ch=prog[p++];
while(ch==‘ ‘)
ch=prog[p++];
if(isalpha(ch)) /*ch为字母字符*/
{
while(isalpha(ch)||isdigit(ch)) /*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)) /*ch是数字字符*/
{
while(isdigit(ch)) /*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;}}

  1. 4.      运行结果及分析

一般必须配运行结果截图,结果是否符合预期及其分析。

 

源代码:

#include<stdio.h> /*定义I/O库所用的某些宏和变量*/
#include<string.h> /*定义字符串库函数*/
#include<conio.h> /*提供有关屏幕窗口操作函数*/
#include<ctype.h> /*分类函数*/
char prog[80]={‘\0‘},
token[8]; /*存放构成单词符号的字符串*/
char ch;
int syn, /*存放单词字符的种别码*/
n,
sum, /*存放整数型单词*/
m,p; /*p是缓冲区prog的指针,m是token的指针*/
char *rwtab[6]={"begin","if","then","while","do","end"};
void scaner(){
m=0;
sum=0;
for(n=0;n<8;n++)
token[n]=‘\0‘;
ch=prog[p++];
while(ch==‘ ‘)
ch=prog[p++];
if(isalpha(ch)) /*ch为字母字符*/
{
while(isalpha(ch)||isdigit(ch)) /*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)) /*ch是数字字符*/
{
while(isdigit(ch)) /*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;}}
main()
{

p=0;
printf("请输入字符与符号:\n");
do {
ch=getchar();
prog[p++]=ch;
}while(ch!=‘#‘);

p=0;
do{
scaner();
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();
}

 

 

 

 

 

四、实验总结

通过本次实验,我又进一步对词法分析原理的理解。对我来说,收获匪浅!

时间: 2024-07-28 13:33:40

201506110111-陈泽翔-实验一报告的相关文章

130242014074 林泽民 实验一

实验报告一 课程    软件体系结构     实验名称  实验一.软件设计的网络支持环境              第      页 专业____   软件工程___________  班级___  2班______  学号___   130242014074____ ____   姓名      林泽民 实验日期:   2017 年 9  月  14 日   报告退发 (订正 . 重做) 一.实验目的 (1)复习软件工程的重要概念,熟悉软件体系结构与软件设计技术的基本概念与内容. (2)通过因

信息安全系统设计基础实验三报告

本次实验三报告由搭档20135338黎静撰写,博客地址链接:http://www.cnblogs.com/heiguirenxi/p/5008521.html

20135130实验三报告

实验三报告 北京电子科技学院(BESTI) 实     验    报     告 课程:Java 班级: 1351    姓名:王川东  学号:20135130 成绩:              指导教师:娄嘉鹏    实验日期:2015.5.8 实验密级:          预习程度:          实验时间:15:30~18:00 仪器组次:20         必修/选修:选修      实验序号:02 实验名称:敏捷开发与XP实践 实验仪器: 名称 型号 数量 计算机 lenovo

20145301《Java程序设计》实验二报告:Java面向对象程序设计

20145301<Java程序设计>实验二报告:Java面向对象程序设计 课程:Java程序设计 实验名称:Java面向对象程序设计 实验目的与要求: 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 了解设计模式 实验内容: 使用TDD的方式设计关实现复数类Complex 程序设计思路: 需求分析: 复数运算需要分:实部和虚部. 需要运行四则运算,即加.减.乘.除四种运算.  需要用户有输入,所以调用了Scanner实例,i

20172311 2017-2018-2 《程序设计与数据结构》实验一报告

20172311 2017-2018-2 <程序设计与数据结构>实验一报告 课程:<程序设计与数据结构> 班级: 1723 姓名: 赵晓海 学号:20172311 实验教师:王志强 实验日期:2018年3月21日 必修/选修: 必修 1.实验内容 (1).学会使用IEDA简单地调试程序. (2).使用jdb编译.运行简单的Java程序: (3).学会在IEDA中以及在使用JDK时设置断点并单步执行. (4).验收pp2.5,pp3.3,pp3.5,pp3.8. 2.实验过程及结果

20172330 2017-2018-2 《程序设计与数据结构》实验一报告

20172330 2017-2018-2 <程序设计与数据结构>实验x报告 课程:<程序设计与数据结构> 班级: 1723 姓名: 李楠 学号:20172330 实验教师:王志强 实验日期:2018年3月21日 必修/选修: 必修 1.实验内容 进行PP2.5,PP3.3,PP3.5,PP3.8,的编译 关于安装调试IDEA,JDK: 实验过程及结果 刚开始是在网上下载的IDEA,然后老师说先要弄jdk,然后就通过U盘复制别已经下好的jdk拷贝到电脑上,按照娄老师的那篇博客一步步安

20172323 2017-2018-2 《程序设计与数据结构》实验1报告

20172323 2017-2018-2 <程序设计与数据结构>实验1报告 课程:<程序设计与数据结构> 班级: 1723 姓名: 王禹涵 学号:20172323 实验教师:王志强 实验日期:2018年3月21日 必修/选修: 必修 1.实验内容 1.学习Java开发环境的熟悉(Linux + Eclipse)和Intellj IDEA 简易教程 2.练习(通过命令行和IDEA两种方式实现)换成前两周项目内容: 3.练习实验项目PP2.5,PP3.3,PP3.5,PP3.8, 实验

20172325 2017-2018-2 《程序设计与数据结构》实验一报告

---恢复内容开始--- 20172325 2017-2018-2 <程序设计与数据结构>实验一报告 课程:<程序设计与数据结构> 班级: 1723 姓名: 邓煜坤 学号:20172325 实验教师:王志强 实验日期:2018年3月21日 必修/选修: 必修 一.实验内容 1.java开发环境的熟悉以及典型例题的实验: 2.IDEA以及JDK的安装和调试 二.实验过程及结果 关于习题PP3.3.PP3.5和PP3.8的联系,首先是对照课本熟悉知识点,之后进行多次尝试,体会做中学,对

172303 2017-2018-2 《程序设计与数据结构》实验二报告

172303 2017-2018-2 <程序设计与数据结构>实验二报告 课程:<程序设计与数据结构> 班级: 1723 姓名: 范雯琪 学号:20172303 实验教师:王志强 助教:张旭升/刘伟康 实验日期:2018年4月17日 必修/选修: 必修 1.实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O.L.I.D原则 了解设计模式 完成蓝墨云上 (1)-(5)实验. 2.实验过程及结果 过程: 本次实验老师一共设置了5