词法分析程序设计与实现.doc

  1. 1、本文档共30页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
1 - 计算机科学与工程系 编译原理课程设计实验报告 姓名:__ ******__ 学号_ *******__ 年级专业及班级___**计算机科学与技术 成绩 实验名称 词法分析程序设计与实现 完成日期 20**/4/12 指导教师 ******* 实验目的:能够采用C编程语言实现简单的词法分析程序;设计、编制并调试一个词法分析程序,加深对词法分析原理的理解 实验要求: 1. 对单词的构词规则有明确的定义; 2. 编写的分析程序能够正确识别源程序中的单词符号; 3. 识别出的单词以单词符号,种别码的形式保存在符号表中(链表); 4. 词法分析中源程序的输入以.c格式,分析后的符号表,将二元组保存在.txt文件中。 实验内容:选择高级语言(C语言),编制它的词法分析程序。词法分析程序的实现可以采用任何一种编程工具 实验原理:1、算法的基本任务是从字符串表示的源程序中识别出具有独立意义的单词符号; 2、其基本思想是根据扫描到单词符号的第一个字符的种类,拼出相应的单词符号。 实验分析:(1)关键字:if else while do case int break等所有的关键字都是小写。 (2)运算符和界符: = + - * / = = = ; ( ) 等 (3)其他单词是标识符(ID)和整型常数(SUM),通过以下正规式定义: ID = _ | letter (letter | digit)* NUM = digit digit* (4)空格有空白、制表符和换行符组成。空格一般用来分隔ID、SUM、运算符、界符和关键字,词法分析阶段通常被忽略。 (5)注释被忽略 (6)各种单词符号对应的种别码(如下): 单词符号 种别码 单词符号 种别码 auto 1 double 2 int 3 struct 4 break 5 else 6 long 7 switch 8 case 9 enum 10 register 11 typedef 12 char 13 extern 14 return 15 union 16 const 17 float 18 short 19 unsigned 20 continue 21 for 22 signed 23 void 24 default 25 goto 26 sizeof 27 volatile 28 do 29 while 30 static 31 if 32 \a 33 \b 34 \f 35 \n 36 \t 37 \v 38 \\ 39 \? 40 \’ 41 \” 42 \0 43 \ddd 44 \ xhh 45 数字 46 标识符 47 # 48 ( 49 ) 50 [ 51 ] 52 { 53 } 54 ‘ 55 * 56 : 57 ~ 58 % 59 ^ 60 + 61 ? 62 = 63 | 64 65 ! 66 67 68 = 69 == 70 71 != 72 73 74 = 75 || 76 ++ 77 ?= 78 - 79 -- 80 - 81 “ 82 %A(A可为d’s’c) 83 ; 84 _ 85 / 86 87 88 89 90 91 其他类别 99 实验流程图(由于流程图过大因此各部分分开写): 整体 : 扫描注释: 扫描数字: 扫描引号: 扫描单词: 扫描其他字符: 实验环境:需要TC、VC++ 6.0等开发工具作为本次试验的环境。 实验步骤: 1、准备: 用TC、VC++等开发工具; 2、对本实验的任务进行分析,确定实现功能的函数; 3、写好程序,仔细修改函数; 4、上机操作:输入源程序,修改、调试,运行。 5、写好试验报告。 实验调试过程及测试结果 /*******************************源代码******************************/ #includestdio.h #includestdlib.h #include ctype.h #includestring.h void main() { FILE *fp,*fp1; int hanjsq=1;//行计数器,保存行号 int guanjz(char ch1[]);//关键字和标识符判断 char ch,infile[15],outfile[15];//定义输入和输出文件名 printf(*****************Enter the infile name*******************\n); scanf(%s,infile);//输入需要扫描的文件名 printf(*************

文档评论(0)

qqbbc1234 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档