编制一个读单词过程,从输入的源程序中,识别出各个具有独立意义的单词,即基本保留字、标识符、常数、运算符、分隔符五大类。并依次输出各个单词的内部编码及单词符号自身值。

上传者: keyu1711 | 上传时间: 2019-12-21 20:03:23 | 文件大小: 433KB | 文件类型: rar
实验一:词法分析 一、实验目的 通过设计一个具体的词法分析程序,加深对词法分析原理的理解。并掌握在对程序设计语言源程序进行扫描过程中将其分解为各类单词的词法分析方法。 编制一个读单词过程,从输入的源程序中,识别出各个具有独立意义的单词,即基本保留字、标识符、常数、运算符、分隔符五大类。并依次输出各个单词的内部编码及单词符号自身值。 二、实验预习提示 1、 词法分析器的功能和输出格式 词法分析器的功能是输入源程序,输出单词符号。词法分析器的单词符号常常表示成以下的二元式(单词种别码,单词符号的属性值)。本实验中,采用的是一类符号对应一个种别码的方式。 2、 单词的BNF表示 ----> ----> ----> + ----> - 等等 3、 模块结构(见课本P95-96)(可根据自己的理解适当修改) 三、实验过程和指导: (一) 准备: 1. 阅读课本有关章节,明确语言的语法,写出基本保留字、标识符、常数、运算符、分隔符和程序例。 2. 初步编制好程序。 3. 准备好多组测试数据。 (二) 上机: (三) 程序要求: 1. 要求用C++Builder或者Dephi或者VC、VB等可视化编程工具编写;要求有界面(即一般windows下应用程序界面)。 2. 输入为某语言源代码。 程序输入/输出示例: 如源程序为C语言。输入如下一段: main() { int a,b; a=10; b=a+20; } 要求输出如下(并以文件形式输出)。 (2,”main”) (5,”(“) (5,”)“) (5,”{“} (1,”int”) (2,”a”) (5,”,”) (2,”b”) (5,”;”) (2,”a”) (4,”=”) (3,”10”) (5,”;”) (2,”b”) (4,”=”) (2,”a”) (4,”+”) (3,”20”) (5,”;”) (5,”}“) 注:为右大括号 要求(可根据实际情况加以扩充和修改): 识别保留字:if、int、for、while、do、return、break、continue等等,单词种别码为1。 其他的标识符,单词种别码为2。 常数为无符号数,单词种别码为3。 运算符包括:+、-、*、/、=、>、=、<=、!= ;单词种别码为4。 分隔符包括: “,”“;”“(”“)”“{”“}”等等, 单词种别码为5。 (四) 程序思路(仅供参考): 0. 定义部分:定义常量、变量、数据结构。 1. 初始化:从文件将源程序输入到字符缓冲区中。 2. 取单词前:去掉多余空白。调用过程GETNB(); 3. 提取字符组成单词,利用课本P97图4.5转换图构造单词扫描过程SCAN(),需要根据实际情况加以修改。 4. 判断单词的种别码,调用过程LOOKUP(); 5. 显示(导出)结果。

文件下载

资源详情

[{"title":"( 17 个子文件 433KB ) 编制一个读单词过程,从输入的源程序中,识别出各个具有独立意义的单词,即基本保留字、标识符、常数、运算符、分隔符五大类。并依次输出各个单词的内部编码及单词符号自身值。","children":[{"title":"词法分析","children":[{"title":"Project1.obj <span style='color:#111;'> 17.38KB </span>","children":null,"spread":false},{"title":"说明文件.txt <span style='color:#111;'> 76B </span>","children":null,"spread":false},{"title":"Unit1.obj <span style='color:#111;'> 232.50KB </span>","children":null,"spread":false},{"title":"分析程序.cpp <span style='color:#111;'> 8.73KB </span>","children":null,"spread":false},{"title":"Project1.exe <span style='color:#111;'> 51.50KB </span>","children":null,"spread":false},{"title":"Unit1.dfm <span style='color:#111;'> 2.67KB </span>","children":null,"spread":false},{"title":"Unit1.~cpp <span style='color:#111;'> 6.77KB </span>","children":null,"spread":false},{"title":"Project1.bpr <span style='color:#111;'> 3.13KB </span>","children":null,"spread":false},{"title":"Unit1.~dfm <span style='color:#111;'> 2.67KB </span>","children":null,"spread":false},{"title":"Project1.cpp <span style='color:#111;'> 1.04KB </span>","children":null,"spread":false},{"title":"Project1.res <span style='color:#111;'> 876B </span>","children":null,"spread":false},{"title":"Unit1.h <span style='color:#111;'> 1.24KB </span>","children":null,"spread":false},{"title":"Unit1.ddp <span style='color:#111;'> 51B </span>","children":null,"spread":false},{"title":"Unit1.~ddp <span style='color:#111;'> 51B </span>","children":null,"spread":false},{"title":"Project1.tds <span style='color:#111;'> 2.06MB </span>","children":null,"spread":false},{"title":"Unit1.cpp <span style='color:#111;'> 6.77KB </span>","children":null,"spread":false},{"title":"Unit1.~h <span style='color:#111;'> 1.24KB </span>","children":null,"spread":false}],"spread":false}],"spread":true}]

评论信息

  • qq_38512953 :
    挺有用的资源
    2018-06-26
  • (成长中)扫地僧 :
    通过什么软件怎么运行啊
    2017-10-26
  • chenmin8978 :
    貌似没有利用自动机,不过还是谢谢
    2017-06-04
  • qq294235090 :
    感觉还行 但是对我并没有什么作用
    2015-08-19
  • xiaxue5420 :
    资源不错,很基础很适合学习
    2014-05-08

免责申明

【只为小站】的资源来自网友分享,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,【只为小站】 无法对用户传输的作品、信息、内容的权属或合法性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论 【只为小站】 经营者是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。
本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二条之规定,若资源存在侵权或相关问题请联系本站客服人员,zhiweidada#qq.com,请把#换成@,本站将给予最大的支持与配合,做到及时反馈和处理。关于更多版权及免责申明参见 版权及免责申明