ImageVerifierCode 换一换
格式:DOCX , 页数:15 ,大小:136.01KB ,
资源ID:3853337      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/3853337.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(词法分析器.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

词法分析器.docx

1、词法分析器 学号:0740303104姓名:雷凤实验一 词法分析设计一、实验目的通过本实验的编程实践,使学生了解词法分析的任务,掌握词法分析程序设计的原理和构造方法,使学生对编译的基本概念、原理和方法有完整的和清楚的理解,并能正确地、熟练地运用。二、实验内容用VC+/VB/JAVA语言实现对C语言子集的源程序进行词法分析。通过输入源程序从左到右对字符串进行扫描和分解,依次输出各个单词的内部编码及单词符号自身值;若遇到错误则显示“Error”,然后跳过错误部分继续显示 ;同时进行标识符登记符号表的管理。以下是实现词法分析设计的主要工作:(1)从源程序文件中读入字符。(2)统计行数和列数用于错误单

2、词的定位。(3)删除空格类字符,包括回车、制表符空格。(4)按拼写单词,并用(内码,属性)二元式表示。(属性值token的机内表示)(5)如果发现错误则报告出错(6)根据需要是否填写标识符表供以后各阶段使用。单词的基本分类: 关键字:由程序语言定义的具有固定意义的标识符。也称为保留字例如 if、 for、while、printf ; 单词种别码为1。 标识符:用以表示各种名字,如变量名、数组名、函数名; 常数: 任何数值常数。如 125, 1,0.5,3.1416; 运算符:+、-、*、/; 关系运算符: 、=、; 分界符: ;、,、(、)、;三、词法分析实验设计思想及算法 1、主程序设计考虑

3、: 程序的说明部分为各种表格和变量安排空间。在具体实现时,将各类单词设计成结构和长度均相同的形式,较短的关键字后面补空。 k数组-关键字表,每个数组元素存放一个关键字(事先构造好关键字表)。s 数组-存放分界符表(可事先构造好分界符表)。为了简单起见,分界符、算术运算符和关系运算符都放在s表中(编程时,应建立算术运算符表和关系运算符表,并且各有类号),合并成一类。 id 和ci 数组分别存放标识符和常数。 instring 数组为输入源程序的单词缓存。 outtoken 记录为输出内部表示缓存。 还有一些为造表填表设置的变量。 主程序开始后,先以人工方式输入关键字,造k表;再输入分界符等造 p

4、 表。 主程序的工作部分设计成便于调试的循环结构。每个循环处理一个单词;接收键盘上送来的一个单词;调用词法分析过程;输出每个单词的内部码。例如,把每一单词设计成如下形式: (type,pointer)其中type指明单词的种类,例如:Pointer指向本单词存放处的开始位置。还有一些为造表填表设置的变量。 主程序开始后,先以人工方式输入关键字,造k表;再输入分界符等造 p 表。 主程序的工作部分设计成便于调试的循环结构。每个循环处理一个单词;接收键盘上送来的一个单词;调用词法分析过程;输出每个单词的内部码。例如,把每一单词设计成如下形式: (type,pointer)其中type指明单词的种类

5、,例如:Pointer指向本单词存放处的开始位置。词法分析设计流程图2、词法分析过程考虑 根据输入单词的第一个字符(有时还需读第二个字符),判断单词类,产生类号:以字符k表示关键字;id表示标识符;ci表示常数;s 表示分界符。 对于标识符和常数,需分别与标识符表和常数表中已登记的元素相比较,如表中已有该元素,则记录其在表中的位置,如未出现过,将标识符按顺序填入数组 id 中,将常数变为二进制形式存入数组中 ci 中,并记录其在表中的位置。lexical 过程中嵌有两个小过程:一个名为 getchar,其功能为从 instring 中按顺序取出一个字符,并将其指针 pint 加 1 ;另一个名

6、为 error,当出现错误时,调用这个过程,输出错误编号。 要求:所有识别出的单词都用两个字节的等长表示,称为内部码。第一个字节为 t ,第二个字节为 i 。 t 为单词的种类。关键字的 t=;分界符的 t=;算术运算符的 t=;关系运算符的 t=;无符号数的 t=;标识符的 t=。i 为该单词在各自表中的指针或内部码值。表 1 为关键字表;表 2 为分界符表;表 3 为算术运算符的 i 值;表 4 为关系运算符的 i 值。 取字符和统计字符行列位置子程序四、实验要求1、编程时注意编程风格:空行的使用、注释的使用、缩进的使用等。2、将标识符填写的相应符号表须提供给编译程序的以后各阶段使用。3、

7、根据测试数据进行测试。测试实例应包括以下三个部分: 全部合法的输入。 各种组合的非法输入。 由记号组成的句子。4、词法分析程序设计要求输出形式:例:输入VC+语言的实例程序:If i=0 then n+;a= 3b %);输出形式为:单词 二元序列 类 型 位置(行,列) (单词种别,单词属性)for (1,for ) 关键字 (1,1) i ( 6,i ) 标识符 (1,2)= ( 4,= ) 关系运算符 (1,3)0 ( 5,0 ) 常数 (1,4)then ( 1,then) 关键字 (1,5)n (6,n ) 标识符 (1,6)+ Error Error (1,7); ( 2, ; )

8、 分界符 (1,8)a (6,a ) 标识符 (2,1)= (4,= ) 关系运算符 (2,2)3b Error Error (2,4)% Error Error (2,4)) ( 2, ) ) 分界符 (2,5); ( 2, ; ) 分界符 (2,6)五、 源代码#include #include /包含函数malloc#include /isalpha和isdigit函数会用到#include #define NULL 0FILE *fp;/fp为文件指针,用来打开一个文件char cbuffer;/char *key11=if,else,for,while,int,return,brea

9、k,continue,then,goto,char;/关键字char *border6=,;,(,);/分界符char *arithmetic5=+,-,*,/,=;/运算符char *relation6=,=,!=;/关系运算符char *consts20;/常数char *label20;/标识符int constnum=0,labelnum=0;int search(char searchchar,int wordtype)/searchchar是字符串数组,用于接收按值传递的参数 和wordtype一样 int i=0; switch (wordtype) /wordtype为单词种别

10、码 case 1: for (i=0;i=10;i+)/返回在关键字数组中的位置 if (strcmp(keyi,searchchar)=0) return(i+1); return 0; case 2: for (i=0;i=5;i+)/返回在分界符表中的位置 if (strcmp(borderi,searchchar)=0) return(i+1); return(0); case 3: for (i=0;i=4;i+)/返回在运算符表中的位置 if (strcmp(arithmetici,searchchar)=0) return(i+1); return(0); case 4: for

11、 (i=0;i=5;i+)/返回在关系运算符表中的位置 if (strcmp(relationi,searchchar)=0) return(i+1); return(0); case 5: for (i=0;iconstnum;i+)/constnum不是为0吗? if (strcmp(constsi,searchchar)=0) return(i+1);/常数在表中,记录在表中的位置 constsi=(char *)malloc(sizeof(searchchar);/malloc strcpy(constsi,searchchar);/将输入的这个常数填入consts常数数组中 cons

12、tnum+;/常数数组的长度加1 return(i+1); case 6: for (i=0;i)/关系运算符 buffer=fgetc(fp); if (buffer=) printf(= 4,5)n); buffer=fgetc(fp); goto out; if (buffer=) buffer=fgetc(fp); if (buffer=) printf(= 4,2)n); buffer=fgetc(fp); goto out; if (buffer=) buffer=fgetc(fp); if (buffer=) printf(= 4,3)n); buffer=fgetc(fp);

13、goto out; if (otype=search(othertp,4) printf(%s,4,%d)n,othertp,otype); buffer=fgetc(fp); goto out; if (otype=search(othertp,2)/分界符 printf(%s,2,%d)n,othertp,otype); buffer=fgetc(fp); goto out; if (buffer!=n)&(buffer!= )/查找分界符表没找到 printf(%c error,not a wordn,buffer); buffer=fgetc(fp);out: return(buffer);void main() int i; for (i=0;i= 4,5)(b,6,2)(;,2,2)(then,1,9)(goto,1,10)(;,2,2)Anysis EndPress any key to continue七、心得体会好长时间没用C+了,刚开始编程时很吃力,所以在写这个程序时遇到了些困难,看着报错的程序有时也找不到出错的地方,所以在完全把这个程序写正确前,同学也帮我改掉了不少错误。我的这个程序实现的功能不是很强,也没有进行8进制和16进制的转换,所以,我以后的编程能力还是有待于提高的。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1