《编译原理》实验项目
12页1、实验一 手工构造简单词法分析程序(必修)一、实验目的了解词法分析程序的基本构造原理,掌握简单词法分析程序的手工构造方法。二、实验内容对从键盘输入或从文件读入的形如:“const count=10,sum=81.5,char1=f,string1=”hj”, max=169;”的常量说明串进行处理,分析常量说明串中各常量名、常量类型及常量值,并统计各种类型常量个数。三、实验要求1、输入的常量说明串,要求最后以分号作结束标志;2、根据输入串或读入的文本文件中第一个单词是否为“const”判断输入串或文本文件是否为常量说明内容;3、识别输入串或打开的文本文件中的常量名。常量名必须是标识符,定义为字母开头,后跟若干个字母,数字或下划线;4、根据各常量名紧跟等号“=”后面的内容判断常量的类型。其中:字符型常量定义为放在单引号内的一个字符;字符串常量定义为放在双引号内所有内容;整型常量定义为带或不带+、- 号,不以0开头的若干数字的组合;实型常量定义为带或不带+、- 号,不以0开头的若干数字加上小数点再后跟若干数字的组合;5、统计并输出串或文件中包含的各种类型的常量个数;6、以二元组(类型,值)的
2、形式输出各常量的类型和值;7、根据常量说明串置于高级语言源程序中时可能出现的错误情况,模仿高级语言编译器对不同错误情况做出相应处理。四、运行结果1、输入如下正确的常量说明串:const count=10,sum=81.5,char1=f,max=169,str1=“h*54 2.4S!AAsj”, char2=,str2=“aa!+h”;输出:count(integer,10)sum(float,81.5)char1(char, f)max(integer,169)str1(string,“h*54 2.4S!AAsj”)char2(char, )str2(string,“aa!+h”)int_num=2; char_num=2; string_num=2; float_num=1.2、输入类似如下的保留字const错误的常量说明串:Aconstt count=10,sum=81.5,char1=f;输出类似下面的错误提示信息:It is not a constant declaration statement! Please input a string again!3、输入类似如下
3、含常量名或常量值错误的常量说明串:const count=10,12sum=81.5,char1=ff,max=0016;输出类似下面的错误提示信息:count(integer,10)12sum(Wrong! It is not a identifier!)char1(Wrong! There are more than one char in .)max(Wrong! The integer cant be started with 0.)int_num=1; char_num=0; string_num=0; float_num=0.4、其他类型的错误处理情况(略)。五、实验提示本实验重点有三个:一是作为常量名的标识符的识别;二是如何根据“=”后出现的内容来判断常量类型;三是对各种错误的处理。难点是对整型和实型常量的判断必须综合考虑多种可能情况。提示:1、 用指针或数组与指针相结合来处理输入的常量说明串;2、 对整型和实型常量处理时,重点考虑常数中0的位置。六、分析与讨论1、若考虑用E或e的科学计数法来表示整数和实数,应该如何实现?2、若考虑布尔型常量,且规定其值只能为true或f
4、alse,应该如何实现?3、如何对手工构造的词法分析程序做进一步的优化,以提高代码质量和运行效率?七、建议实验学时本次实验建议学时6-8学时。实验二 用FLEX/LEX构造简单词法分析程序(必修)一、实验目的1、熟悉词法分析程序生成器FLEX/LEX的基本使用及其源程序的编写方法;2、掌握FLEX/LEX源程序中模式的构造方法;3、掌握在C源程序中使用FLEX/LEX生成的C语言模块的方法;二、实验内容1、编制一个FLEX源程序,统计任意给出的一个文本文件中字母,数字,回车符的个数;2、用FLEX自动生成简单词法分析程序。三、实验要求1、参考附录A,熟悉FLEX/LEX的基本使用方法;2、用FLEX自动生成简单词法分析程序的实验内容,即完成实验一中对给定常量说明串的词法分析,其具体要求如下:(1)根据输入串或打开的文本文件中第一个单词是否为“const”判断输入串或文本文件是否为常量说明内容;(2)识别输入串或打开的文本文件中作常量名的标识符。标识符定义为字母开头,后跟若干个字母,数字或下划线;(3)识别输入串或打开的文本文件中的等号“=”,并根据其右边的内容判断常量的类型。其中:字符
《《编译原理》实验项目》由会员hs****ma分享,可在线阅读,更多相关《《编译原理》实验项目》请在金锄头文库上搜索。
2023年数据挖掘实验报告对电信客户的分析
农村幸福院管理办法
赴四川重庆等地学习考察报告定稿
IC资料第三十六节VCT77VWP平板显示器和双扫描电视视
人教版 高中数学【选修 21】 创新应用教学案:第一章章末小结与测评
高效复合助熔剂项目商业计划书写作参考
峨山县精细化工项目可行性研究报告【范文】
商业合作协议范文(9篇)
2022年对口支援工作计划模板
2016年--2017年五年级上册数学教学案(全册)
如何做文明的小学生三年级作文3篇文明行为的作文三年级
借款合同标准模板(九篇).doc
酒店前台接待年终工作总结模板(3篇).doc
医药学药店实习报告总结范文
《JAVA面向对象程序设计》练习题库B
给水、排水及采暖工程 监理细则
开展农村基层勤廉双优争创活动工作总结
建筑施工安全检查评分表范本
学校安全规范工作计划样本(六篇)
教育局上半年工作总结共4篇
2023-10-23 9页
2023-01-12 9页
2023-04-20 134页
2024-01-13 10页
2022-11-27 7页
2023-10-19 8页
2023-11-26 4页
2022-08-22 19页
2023-08-20 71页
2022-11-03 32页