- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
北邮大三上编译原理词法分析实验报告
编译原理
第三章 词法分析
班级:2009211311
学号:
姓名:schnee
目 录
1. 实验题目和要求 3
2. 检测代码分析 3
3. 源代码………………………………………………………………………………………………….. 4
实验题目和要求
题目:词法分析程序的设计与实现。
实验内容:设计并实现C语言的词法分析程序,要求如下。
(1)、可以识别出用C语言编写的源程序中的每个单词符号,并以记号的形式输出每个单词符号。
(2)、可以识别并读取源程序中的注释。
(3)、可以统计源程序汇总的语句行数、单词个数和字符个数,其中标点和空格不计算为单词,并输出统计结果
(4)、检查源程序中存在的错误,并可以报告错误所在的行列位置。
(5)、发现源程序中存在的错误后,进行适当的恢复,使词法分析可以继续进行,通过一次词法分析处理,可以检查并报告源程序中存在的所有错误。
实验要求:
方法1:采用C/C++作为实现语言,手工编写词法分析程序。
方法2:通过编写LEX源程序,利用LEX软件工具自动生成词法分析程序。
检测代码分析
Hello World简单程序输入:
较复杂程序输入:
3. 异常程序输入检测
三, 源代码
#include cmath
#include cctype
#include string
#include vector
#include cstdio
#include cstdlib
#include cstring
#include fstream
#include iostream
#include algorithm
using namespace std;
const int FILENAME=105;
const int MAXBUF=82;
const int L_END=40;
const int R_END=81;
const int START=0; //开始指针
vectorstring Key; //C保留的关键字表
class funtion //词法分析结构
{
public:
//变量声明
char filename[FILENAME]; //需要词法分析的代码文件名
ifstream f_in;
char buffer[MAXBUF]; //输入缓冲区
int l_end, r_end, forward; //左半区终点,右半区终点,前进指针,
bool l_has, r_has; //辅助标记位,表示是否已经填充过缓冲区
vectorstring Id; //标识符表
char C; //当前读入的字符
int linenum, wordnum, charnum; //行数,单词数,字符数
string curword; //存放当前的字符串
//函数声明
void get_char(); //从输入缓冲区读一个字符,放入C中,forward指向下一个
void get_nbc(); //检查当前字符是否为空字符,反复调用直到非空
void retract(); //向前指针后退一位
void initial(); //初始化要词法分析的文件
void fillBuffer(int pos); //填充缓冲区,0表示左,1表示右
void analyzer(); //词法分析
void token_table(); //以记号的形式输出每个单词符号
void note_print(); //识别并读取源程序中的注释
void count_number(); //统计源程序汇总的语句行数、单词个数和字符个数
void error_report(); //检查并报告源程序中存在的所有错误
void solve(char* file); //主调用函数
};
void welcome()
{
printf(\n*********************************************************\n);
printf( ** Welcome to use LexicalAnalyzer
文档评论(0)