- 1、本文档共10页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
《编译原理》课程实验报告
华东交大理工学院《编译原理》课程实验报告题 目: 词法分析器实验 专 业: 计算机科学与技术 班 级: 1班 学 号: * * * ***** 姓 名: * * * 一、实验目的通过本实验的编程实践,使学生了解词法分析的任务,掌握词法分析程序设计的原理和构造方法,使学生对编译的基本概念、原理和方法有完整的和清楚的理解,并能正确地、熟练地运用。二、实验内容及要求用VC++/VB/JAVA语言实现对C语言子集的源程序进行词法分析。通过输入源程序从左到右对字符串进行扫描和分解,依次输出各个单词的内部编码及单词符号自身值;若遇到错误则显示“Error”,然后跳过错误部分继续显示 ;同时进行标识符登记符号表的管理。以下是实现词法分析设计的主要工作:(1)从源程序文件中读入字符。(2)统计行数和列数用于错误单词的定位。(3)删除空格类字符,包括回车、制表符空格。(4)按拼写单词,并用(内码,属性)二元式表示。(属性值——token的机内表示)(5)如果发现错误则报告出错(6)根据需要是否填写标识符表供以后各阶段使用。单词的基本分类:? 关键字:由程序语言定义的具有固定意义的标识符。也称为保留字例如 if、 for、while、printf ; 单词种别码为1。? 标识符:用以表示各种名字,如变量名、数组名、函数名;? 常数: 任何数值常数。如 125, 1,0.5,3.1416;? 运算符:+、-、*、/;? 关系运算符: 、=、= 、、=、;? 分界符: ;、,、(、)、[、];三、实验程序设计说明1.实验方案设计1、主程序设计考虑:程序的说明部分为各种表格和变量安排空间。在具体实现时,将各类单词设计成结构和长度均相同的形式,较短的关键字后面补空。 k数组------关键字表,每个数组元素存放一个关键字(事先构造好关键字表)。s 数组------存放分界符表(可事先构造好分界符表)。为了简单起见,分界符、算术运算符和关系运算符都放在s表中(编程时,应建立算术运算符表和关系运算符表,并且各有类号),合并成一类。 id 和ci 数组分别存放标识符和常数。 instring 数组为输入源程序的单词缓存。 outtoken 记录为输出内部表示缓存。 还有一些为造表填表设置的变量。 主程序开始后,先以人工方式输入关键字,造k表;再输入分界符等造 p 表。 主程序的工作部分设计成便于调试的循环结构。每个循环处理一个单词;接收键盘上送来的一个单词;调用词法分析过程;输出每个单词的内部码。例如,把每一单词设计成如下形式: (type,pointer)其中type指明单词的种类,例如:Pointer指向本单词存放处的开始位置。还有一些为造表填表设置的变量。 主程序开始后,先以人工方式输入关键字,造k表;再输入分界符等造 p 表。 主程序的工作部分设计成便于调试的循环结构。每个循环处理一个单词;接收键盘上送来的一个单词;调用词法分析过程;输出每个单词的内部码。例如,把每一单词设计成如下形式: (type,pointer)其中type指明单词的种类,例如:Pointer指向本单词存放处的开始位置。词法分析设计流程图2、词法分析过程考虑 根据输入单词的第一个字符(有时还需读第二个字符),判断单词类,产生类号:以字符k表示关键字;id表示标识符;ci表示常数;s 表示分界符。 对于标识符和常数,需分别与标识符表和常数表中已登记的元素相比较,如表中已有该元素,则记录其在表中的位置,如未出现过,将标识符按顺序填入数组 id 中,将常数变为二进制形式存入数组中 ci 中,并记录其在表中的位置。lexical 过程中嵌有两个小过程:一个名为 getchar,其功能为从 instring 中按顺序取出一个字符,并将其指针 pint 加 1 ;另一个名为 error,当出现错误时,调用这个过程,输出错误编号。要求:所有识别出的单词都用两个字节的等长表示,称为内部码。第一个字节为 t ,第二个字节为 i 。 t 为单词的种类。关键字的 t=1;分界符的 t=2;算术运算符的 t=3;关系运算符的 t=4;无符号数的 t=5;标识符的 t=6。i 为该单词在各自表中的指针或内部码值。表 1 为关键字表;表 2 为分界符表;表 3 为算术运算符的 i 值;表 4 为关系运算符的 i 值。 取字符和统计字符行列位置子程序2.程序源代码#includeiostream#includeiomanip#includefstream#includestringusing namespace std;#define MA
您可能关注的文档
- 《数字航空摄影测量》培训教材(终).doc
- 《数学分析原理》英文答案.doc
- 《数数及数的组成》教学分析.doc
- 《数据结构课程设计》哈弗曼树与内部排序性能分析.doc
- 《文书工作与档案管理》整体设计方案.doc
- 《整式加减》整体规划.doc
- 《文学理论教程》教学大纲.doc
- 《文档的修饰》教学案例 初一信息技术ppt课件教案.doc
- 《新能源概论》课程教案.doc
- 《新闻软实力》缩略版.doc
- 2024年甘肃省秦安县《一级注册建筑师之建筑设计》资格考试必背100题大全附参考答案AB卷.docx
- 2024年甘肃省漳县《一级注册建筑师之建筑设计》考试加答案.docx
- 2024上海市电工证考试题模拟试题初级电工实操考试内容(含答案).pdf
- 2024年广东省荔湾区《一级注册建筑师之建筑设计》资格考试必刷100题题库大全及答案(各地真题).docx
- 2024年税务师之涉税服务实务通关题库(附带答案) .pdf
- 2024年甘肃省肃州区《一级注册建筑师之建筑设计》考试附答案【完整版】.docx
- 2024年甘肃省永靖县《一级注册建筑师之建筑设计》资格考试必刷100题真题【模拟题】.docx
- 2024年甘肃省永登县《一级注册建筑师之建筑设计》资格考试必背100题真题题库及解析答案.docx
- 2024年广东省《一级注册建筑师之建筑设计》资格考试必刷100题含答案【模拟题】.docx
- 2024年甘肃省永昌县《一级注册建筑师之建筑设计》资格考试必刷100题内部题库完整参考答案.docx
最近下载
- 单桩竖向抗压静载试验.pptx
- 立足生本,拓展实效—小学语文生本教育思想渗透和实践研究 论文.docx
- HACCP 1.0食品安全文化推行计划.doc
- 反对享乐主义.pptx VIP
- 2023江苏苏州常熟市公安局招聘警务辅助人员(100人)笔试备考题库及答案解析.docx VIP
- 《陕北地区高中英语写作教学问卷调查分析报告》-来源:新课程(下旬)(第2018011期)-山西三晋报刊传媒集团有限责任公司.pdf VIP
- 一种隧道烟尘排放装置.pdf VIP
- 人教版(新教材)七年级上册数学第三单元《数学活动》教学课件.pptx
- KARCHER凯驰卡赫家庭及园艺高压清洗机K 5 Premium Full Control CN用户手册说明书_第3份.pdf
- 2023年山东省聊城市临清市八年级上学期期中英语试题及答案.doc VIP
文档评论(0)