编译原理--词法分析C++

一、实验项目要求

1.实验目的

通过设计编制调试一个具体的词法分析程序,加深对词法分析原理的理解。并掌握在对程序设计语言源程序进行扫描过程中将其分解为各类单词的词法分析方法。

编制一个读单词过程,从输入的源程序中,识别出各个具有独立意义的单词,即基本保留字、标识符、常数、运算符、分隔符五大类。并依次输出各个单词的内部编码及单词符号自身值。(遇到错误时可显示“Error”,然后跳过错误部分继续显示)

2.实验要求

识别保留字:if、int、for、while、do、return、break、continue,等C语言的保留字;单词种别码为1。

其他的都识别为标识符;单词种别码为2。

常数为无符号整形数;单词种别码为3。

运算符包括:+、-、*、/、=、>、<、>=、<=、!= ;单词种别码为4。

分隔符包括:,、;、{、}、(、)、[、]; 单词种别码为5。

二、理论分析或算法分析

在词法分析中,自文件头开始扫描源程序字符,一旦发现符合“单词”定义的源程序字符串时,将它翻译成固定长度的单词内部表示,并查填适当的信息表。经过词法分析后,源程序字符串(源程序的外部表示)被翻译成具有等长信息的单词串(源程序的内部表示),并产生两个表格:常数表和标识符表,它们分别包含了源程序中的所有常数和所有标识符。

0.定义部分:定义常量、变量、数据结构。

1.初始化:从文件将源程序全部输入到字符缓冲区中。

2.取单词前:去掉多余空白。

3.取单词:利用实验一的成果读出单词的每一个字符,组成单词,分析类型。(关键是如何判断取单词结束?取到的单词是什么类型的单词?)

4.显示结果。

三.实现方法

程序流程图如图所示:

四.实验结果分析

实验结果图

遇到的问题

(1)当第一次将代码写进去之后,出现如图所示的错误。

(2)一直找不到example.txt文件,一直出现那个error;

解决办法

(1)将Test1的属性下的C/C++下面的语言的符合模式改为“否”即可。

(2)在目录下导入并且在自建目录下导入,就可以解决这个问题。

在这次实验中,对之前学到的词法分析有了进一步的了解,加深了对于词法分析的步骤的理解与领悟,对于今后对编译原理的学习有很大的帮助。,刚开始把已有代码导入的时候,各种错误,然后就在网上一个一个搜索直到解决问题,在同学的帮助下,顺利的把代码问题搞对。

五、代码

#include <stdio.h>
#include <ctype.h>
#include <malloc.h>
#include <stdlib.h>
#include <string.h>
#define NULL 0
#pragma warning(disable:4996)FILE *fp;
char cbuffer;
char *key[32] = { "if","else","for","break","continue","int","float","double","auto","case","char","const","default","do","enum","long","extern","goto","register","return","short","signed","sizeof","static","struct","switch","typedef","union","unsigned","void","volatile","while" };
char *border[8] = { ",",";","{","}","(",")","[","]" };
char *arithmetic[4] = { "+","-","*","/" };
char *relation[6] = { "<","<=","=",">",">=","<>" };
char *consts[20];
char *label[20];
int constnum = 0, labelnum = 0;
int search(char searchchar[], int wordtype)
{int i = 0;switch (wordtype){case 1:for (i = 0; i <= 31; i++){if (strcmp(key[i], searchchar) == 0)return(i + 1);}return 0;case 2:{for (i = 0; i <= 7; i++){if (strcmp(border[i], searchchar) == 0)return(i + 1);}return(0);}case 3:{for (i = 0; i <= 3; i++){if (strcmp(arithmetic[i], searchchar) == 0){return(i + 1);}}return(0);}case 4:{for (i = 0; i <= 5; i++)if (strcmp(relation[i], searchchar) == 0)return(i + 1);return(0);}case 5:{for (i = 0; i <= constnum; i++){if (consts[i] && (strcmp(consts[i], searchchar) == 0))return(i + 1);}consts[i - 1] = (char *)malloc(sizeof(searchchar));strcpy(consts[i - 1], searchchar);constnum++;return(i);}case 6:{for (i = 0; i <= labelnum; i++)if (label[i] && (strcmp(label[i], searchchar) == 0))return(i + 1);label[i - 1] = (char *)malloc(sizeof(searchchar));strcpy(label[i - 1], searchchar);labelnum++;return(i);}default: return 0;}
}
char alphaprocess(char buffer)
{//	int atype;int i = -1;char alphatp[20];while ((isalpha(buffer)) || (isdigit(buffer))){alphatp[++i] = buffer;buffer = fgetc(fp);}alphatp[i + 1] = '\0';if (/*atype=*/search(alphatp, 1))//		printf("%s (1,%d)\n",alphatp,atype-1);printf("(1,  \"%s\")\n", alphatp);else{search(alphatp, 6);//		printf("%s (6,%d)\n",alphatp,atype-1);printf("(2,  \"%s\")\n", alphatp);}return(buffer);
}char digitprocess(char buffer)
{int i = -1;char digittp[20];//	int dtype;while ((isdigit(buffer))){digittp[++i] = buffer;buffer = fgetc(fp);}digittp[i + 1] = '\0';search(digittp, 5);//	printf("%s (5,%d)\n",digittp,dtype-1);printf("(3,  \"%s\")\n", digittp);return(buffer);
}char otherprocess(char buffer)
{int i = -1;char othertp[20];//	int otype,otypetp;othertp[0] = buffer;othertp[1] = '\0';if (/*otype=*/search(othertp, 3)){//		printf("%s (3,%d)\n",othertp,otype-1);printf("(4,  \"%s\")\n", othertp);buffer = fgetc(fp);goto out;}if (/*otype=*/search(othertp, 4)){buffer = fgetc(fp);othertp[1] = buffer;othertp[2] = '\0';if (/*otypetp=*/search(othertp, 4)){//		printf("%s (4,%d)\n",othertp,otypetp-1);printf("(4,  \"%s\")\n", othertp);goto out;}elseothertp[1] = '\0';//		printf("%s (4,%d)\n",othertp,otype-1);printf("(4,  \"%s\")\n", othertp);goto out;}if (buffer == ':'){buffer = fgetc(fp);if (buffer == '=')printf(":= (2,2)\n");buffer = fgetc(fp);goto out;}else{if (/*otype=*/search(othertp, 2)){//			 printf("%s (2,%d)\n",othertp,otype-1);printf("(5,  \"%s\")\n", othertp);buffer = fgetc(fp);goto out;}}if ((buffer != '\n') && (buffer != ' '))printf("%c error,not a word\n", buffer);buffer = fgetc(fp);out:      return(buffer);
}void main()
{int i;for (i = 0; i <= 20; i++){label[i] = NULL;consts[i] = NULL;}if ((fp = fopen("example.txt", "r")) == NULL)printf("error");else{cbuffer = fgetc(fp);while (cbuffer != EOF){if (isalpha(cbuffer))cbuffer = alphaprocess(cbuffer);else if (isdigit(cbuffer))cbuffer = digitprocess(cbuffer);else cbuffer = otherprocess(cbuffer);}printf("over\n");getchar();}
}

example.txt

#inlclude<stdio.h>
int main()
{
int b, a, c;
a = 10;
c=a+b;
printf("%d%d",a,b);;
return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/297144.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

华为交换机Telnet原理与配置

Telnet远程连接到每一台设备上&#xff0c;对这些网络设备进行集中的管理和维护。 Telnet应用场景 Telnet可以通过终端对本地和远程的网络设备进行集中管理。Telnet提供了一个交互式操作界面&#xff0c;允许终端远程登录到任何可以充当Telnet服务器的设备。Telnet用户可以像通…

指针与数组

&#xff08;1&#xff09;在C语言中&#xff0c;数组的指针是指数组在内存中的起始地址&#xff0c;数组元素的地址是指指数组元素在内存中的起始地址 &#xff08;2&#xff09;一维数组的数组名为一维数组的指针&#xff08;其实地址&#xff09; 设指针变量px的地址值等于…

ros2+gazebo+urdf:ros2机器人使用gazebo的urdf文件中的<gazebo>部分官网资料

原文链接SDFormat extensions to URDF (the gazebo tag) — Documentation 注意了ros2的gazebo部分已经跟ros1的gazebo部分不一样了&#xff1a; Toggle navigation SpecificationAPIDocumentationDownload Back Edit Version: 1.6 Table of C…

HarmonyOS的功能及场景应用

一、基本介绍 鸿蒙HarmonyOS主要应用的设备包括智慧屏、平板、手表、智能音箱、IoT设备等。具体来说&#xff0c;鸿蒙系统是一款面向全场景(移动办公、运动健康、社交通信、媒体娱乐等)的分布式操作系统&#xff0c;能够支持手机、平板、智能穿戴、智慧屏、车机等多种终端设备…

Chainlink 开发者故事:Krypton 从构思到产品的 Chainlink BUILD之旅

识别问题&#xff0c;构思解决方案&#xff0c;建立它&#xff0c;推出它&#xff0c;然后扩展它。这就是科技初创企业的操作手册。 现在&#xff0c;前Chainlink黑客马拉松获奖者&#xff0c;当前的Chainlink BUILD成员Krypton已经进行到了第四步&#xff1a;推出。Krypton团…

基于Flask、MySQL和Echarts的*市CPI和物价水平数据可视化分析

基于Flask、MySQL和Echarts的*市CPI和物价水平数据可视化分析 引言&#xff1a; 在当前社会经济背景下&#xff0c;CPI&#xff08;居民消费价格指数&#xff09;和物价水平的波动对市场和居民生活产生直接影响。本文将介绍一款基于Flask、MySQL和Echarts的数据可视化系统&…

调试备忘录-RS485 MODBUS RTU协议简述

目录--点击可快速直达 目录 写在前面先简单说下什么是MODBUS&#xff1f;参考文章 写在前面 最近在做和物联网有关的小项目&#xff0c;有一个传感器通讯用到了RS485 MODBUS RTU协议,所以就写个随笔记录下。 先简单说下什么是MODBUS&#xff1f; Modbus协议是应用于电子控…

FineBI6.0 忘记管理员密码和用户解决方法

文章目录 问题描述解决思路解决步骤需要注意 问题描述 当我们打开FineBi服务的时候&#xff0c;突然忘记密码&#xff0c;这个时候咱们无需慌张这个时候就体现了记录密码的重要性了&#xff0c;但是不要紧&#xff0c;还是可以用方法找回的。 解决思路 通过更改配置文件db.…

华为HCIA认证H12-811题库新增

801、[单选题]178/832、在系统视图下键入什么命令可以切换到用户视图? A quit B souter C system-view D user-view 试题答案&#xff1a;A 试题解析&#xff1a;在系统视图下键入quit命令退出到用户视图。因此答案选A。 802、[单选题]“网络管理员在三层交换机上创建了V…

鲜花植物企业网站建设的效果如何

从整体来看&#xff0c;似乎鲜花植物只会在线下花市或花店里购买或见到&#xff0c;但其实对鲜花植物批发商或品牌商来说&#xff0c;线上渠道同样重要&#xff0c;从本地来说&#xff0c;流量少且获取难&#xff0c;各家品牌/门店竞争激烈&#xff0c;并且无法全面展示自己的品…

Matlab-修改默认启动路径

Matlab-修改默认启动路径 第一:找到MATLAB的安装路径 第二步&#xff1a;进入到…\toolbox\local下&#xff0c;找到matlabrc.m 第三部&#xff1a;编辑matlabrc.m&#xff0c;在文本最后一行加入启动文件路径

我要正式开始《一个项目征服Java中高级体系》

在互联网上经常看到很多人说35岁危机的问题、大厂裁员、互联网寒冬这些问题。我感觉比较幸运的是&#xff0c;在之前大环境还不是很坏时候就被裁了一次&#xff0c;所以我很早就开始做持续的准备&#xff0c;现在不好说一定能怎么样&#xff0c; 至少自己在持续的探索适合自己的…