北邮大三上-编译原理-词法分析实验报告.docVIP

  • 14
  • 0
  • 约1.03万字
  • 约 17页
  • 2018-01-02 发布于河南
  • 举报

北邮大三上-编译原理-词法分析实验报告.doc

北邮大三上-编译原理-词法分析实验报告

编译原理 第三章 词法分析 班级: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 **\n

文档评论(0)

1亿VIP精品文档

相关文档