下载此文档

词法分析报告设计实验报告材料(附代码).doc


文档分类:高等教育 | 页数:约13页 举报非法文档有奖
1/13
下载提示
  • 1.该资料是网友上传的,本站提供全文预览,预览什么样,下载就什么样。
  • 2.下载该文档所得收入归上传者、原创者。
  • 3.下载的文档,不会出现我们的网址水印。
1/13 下载此文档
文档列表 文档介绍
word
word
1 / 13
word
实验一词法分析设计
实验学时:4
实验类型:综合
实验要求:必修
一、实验目的
通过本实验的编程实践,使学生了解词法分析的任务,掌握词法分析程序设计的原理和构造方法,使学生对编译的根本概念、原理和方法有完整的和清楚的理解,并能正确地、熟练地运用。
二、实验内容
用VC++/VB/JAVA语言实现对C语言子集的源程序进展词法分析。通过输入源程序从左到右对字符串进展扫描和分解,依次输出各个单词的内部编码与单词符号自身值;假如遇到错误如此显示“Error〞,然后跳过错误局部继续显示;同时进展标识符登记符号表的管理。
以下是实现词法分析设计的主要工作:
〔1〕从源程序文件中读入字符。
〔2〕统计行数和列数用于错误单词的定位。
〔3〕删除空格类字符,包括回车、制表符空格。
〔4〕按拼写单词,并用〔内码,属性〕二元式表示。(属性值——token的机内表示)
〔5〕如果发现错误如此报告出错
〔6〕根据需要是否填写标识符表供以后各阶段使用。
单词的根本分类:
关键字:由程序语言定义的具有固定意义的标识符。也称为保存字例如 if、 for、while、printf ;单词种别码为1。
标识符:用以表示各种名字,如变量名、数组名、函数名;
常数:任何数值常数。如;
运算符:+、-、*、/;
关系运算符: <、<=、= 、>、>=、<>;
分界符:; 、, 、〔、〕 、[、];
word
word
2 / 13
word
三、实验要求
1、编程时注意编程风格:空行的使用、注释的使用、缩进的使用等。
2、将标识符填写的相应符号表须提供应编译程序的以后各阶段使用。
3、根据测试数据进展测试。测试实例应包括以下三个局部:
全部合法的输入。
各种组合的非法输入。
由记号组成的句子。
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, ; ) 分界符 〔1,8〕
word
word
3 / 13
word
a (6,a ) 标识符 〔2,1〕
﹤= (4,<= ) 关系运算符 〔2,2〕
3b Error Error 〔2,4〕
% Error Error 〔2,4〕
) ( 2, ) ) 分界符 〔2,5〕
; ( 2, ; ) 分界符 〔2,6〕
实验报告正文:
功能描述:该程序具有词法分析功能,即面对一段程序源代码,通过该程序,能检查出源代码是否由词法错误。
三、词法分析实验设计思想与算法:
首先构造六个表,key[]={"auto","break","case","catch","char","class","const","continue","de

词法分析报告设计实验报告材料(附代码) 来自淘豆网m.daumloan.com转载请标明出处.

相关文档 更多>>
非法内容举报中心
文档信息
  • 页数13
  • 收藏数0 收藏
  • 顶次数0
  • 上传人beny00001
  • 文件大小178 KB
  • 时间2021-12-20