编译原理实验

上传人:枫** 文档编号:408785818 上传时间:2022-11-01 格式:DOC 页数:12 大小:63.50KB
返回 下载 相关 举报
编译原理实验_第1页
第1页 / 共12页
编译原理实验_第2页
第2页 / 共12页
编译原理实验_第3页
第3页 / 共12页
编译原理实验_第4页
第4页 / 共12页
编译原理实验_第5页
第5页 / 共12页
点击查看更多>>
资源描述

《编译原理实验》由会员分享,可在线阅读,更多相关《编译原理实验(12页珍藏版)》请在金锄头文库上搜索。

1、实验一 编写词法实验程序(题目字体为华文中宋,三号字体)一.实验小组成员及任务分解(黑体,小四)本组共有4个成员,本组全总成员参与程序代码的输入,每人输入2到3张程序代码不等,最后合并每个成员输入的程序段进行编译连接,修改错误,最终改正了程序,得到了正确的运行结果,最后制作出了实验报告电子文档。实验过程中每一个成员的任务如下:姓名任务杨成凡程序代码输入、编译、报告制作刘春香程序代码输入、编译、报告制作曹卓程序代码输入、编译、报告制作李论编译、报告制作二.实验目的和要求(黑体,小四)通过设计、调试词法分析程序,实现从源程序中分出各种单词的方法;熟悉词法分析程序所用的工具自动机,进一步理解自动机理

2、论。掌握文法转换成自动机的技术及有穷自动机实现的方法。确定词法分析器的输出形式及标识符与关键字的区分方法。加深对课堂教学的理解;提高此法分析方法的实践能力。通过本实验达到一下目标:1、掌握从源程序文件中读取有效字符的方法和生产源程序的内部表示文件的方法。2、掌握此法分析的实现方法。3、上机调试编出的词法分析程序。三. 背景知识(黑体,小四)词法分析的背景知识:词法分析就是把组成说明和语句的单词逐个识别出来,给出单词的类别及其他属性,以供语法分析用。执行词法分析功能的程序称为词法分析程序,也称为词法分析器或词法扫描器,词法分析器可借助于有限自动机等工具手工构造或自动生成。词法分析器的作用:词法分

3、析器(也称词法分析程序)的主要作用是根据单词的文法,把源程序中的单词逐个识别出来,并给出各个单词包括类别在内的属性。一般的高级语言中,单词由如下几个类别:(1) 标识符;(2) 关键字*(从文法上看,关键字集合是标识符集合的子集合);(3) 常数,包括整常数、实常数(或称浮点数)、字符常数、字符串常数等;(4) 运算符,如+,*,/等;(5) 分隔符,如逗号(,)、冒号(:)、分号(;)等。词法分析器每识别出一个单词,要给出该单词所属的类别,此外还要给出该单词(语法分析需的)其他属性。对于标识符来说,还要给出它的源程序表示(即构成标识符的字符串);对于关键字来说,还要给出它在关键字表中的地址或

4、序号;对常数来说,还要给出它在常数表中的地址或序号;对于运算符和分隔符,还要给出它的源程序表示(即源程序中的形式)或编号。词法分析器还提供单词在源程序中的位置信息,即行号和列号,也供错误处理部分使用。在分析过程中,词法分析器要略掉源程序中的注释。词法分析器的构造方法:构造词法分析器既可以手工完成,也可以利用LEX处理系统自动完成。手工构造词法分析器一般都借助于状态转移图 。状态转移图是一个有穷有向图,它关联一个入字母表。图中的结点代表状态,状态之间的有向边标有取自输入字母表中的字母。图中的状态有一个是初始状态,还有若干个终止状态。在描述单词识别过程的转移图中,当尚未读取构成单词的任何字符时,处

5、于初始状态;处于某个终止状态时,表示识别出一个单词。通常,在初始状态左边加一个箭头,以表示它是初始状态;终止状态用双圆圈表示,非终止状态用单圆圈表示。状态0是初始状态,处于状态0时,表示尚未读入构成标识符的任何字符;到状态1时,表示已读入了若干个字母、数字,并且读入的第1个字符一定是字母;到状态2时,表示已识别出一个标识符,即读入的字符序列恰好 构成了一个标识符。状态2右边加一个*,表示到达该状态时,多读了一个不属于标识符的字符。LEX是一个词法分析器的自动生成系统。LEX语言可用于描述单词的结构,LEX处理系统根据LEX语言源程序提能吸供单词结构信息,自动生成分析这些单词的词法分析程序。LE

6、X语言用正则表达式描述单词的结构,LEX处理系统根据LEX语言中的描述单词结构正则式R生成相应的有限状态自动机M,满足L(R)=L(M),再根据M生成相应的词法分析程序。此法分析师作为相对独立的阶段来完成的。在词法分析的过程中,编译程序是通过操作系统从外部介质中读取源程序文件中的各个字符的。同时为正确的 识别单词,有时还需进行超前搜索和回退字符等操作。因此,为了提高读盘效率和便于扫描器进行工作,通常可以采取缓冲输入的方案,即在内存中设置一个适当大小的输入缓冲区,让操作系统直接将磁盘上的源程序字符串分批送入此缓冲区中,供扫描器进行处理。四. 实验内容及算法设计#include#includech

7、ar *KeyWord32=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;int i=0,j=0,k=0,t=0;char ch;char strToken20;char *chr_form100;char *int_form100;char for

8、m1000;int q=0;void GetChar() ch=formk;k+;void GetBC()while(ch= )GetChar();void Concat() strTokeni=ch; i+;bool isLetter() if(ch=a&ch=A&ch=0&ch=9) return true;elsereturn false;/第3,4篇/第5,6页int SearchKeyWord() for(int q=0;q32;q+) if(strcmp(strToken,KeyWordq) return q;/是关键字 if(q=32)return -1;/是字符串void Re

9、set() k-; ch=NULL;char*InsertChar()/将strToken中的标识符插入符号表,返回符号表的指针 chr_formj=strToken; j+;return chr_form0;char*InsertInt()/将strToken中的常数插入长鼠标,返回常数表指针 int_formt=strToken; t+; return int_form0;int code;void analyze() GetChar(); GetBC(); if(isLetter() /如果是字符 while(isLetter()|isDigit() Concat(); GetChar(

10、);Reset();code=SearchKeyWord();switch(code)case-1:cout字符串,strTokenendl;break;default:cout关键字,strTokenendl;break;else if(isDigit()/是数字 while(isDigit()|ch=.) Concat(); GetChar(); Reset(); cout是数字,strTokenendl; else switch(ch) case =: case *: case %:cout运算符,chendl;break; case _:GetChar(); if(ch=_)coute

11、ndl; elseReset();coutendl; break;/第7页case+:GetChar();if(ch=+)coutendl;elseReset();coutendl;break;case|:GetChar();if(ch=|)coutendl;elseReset();cout非法符号endl;break;case&:GetChar();if(ch=&)coutendl;break;case/:GetChar();if(ch=/)doGetChar();while(ch!=n);coutendl;elseReset();coutendl;break;case;:case(:cas

12、e):case:case:case:case:case:case,:case:cout界符, chendl;break;case:GetChar();/第8页 if(ch=)cout运算符,endl; elseReset();cout:GetChar();if(ch=+)coutendl;elseReset();coutendl;break;while(kq) for(int p=0;p20;p+) strTokenp=0; i=0; analyze(); void main() cout请输入一段C语言程序,以符号结尾:endl; form0=cin.get(); for(q=1;formq-1!=;q+) formq=cin.get(); if(formq=)

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号