编译原理--词法分析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.mzph.cn/news/350504.shtml

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

相关文章

python list转map_Python 进阶之术 Map Filter Reduce

" 本文字数&#xff1a;763 字 || 阅读时间&#xff1a;3分钟"Map Map 会将⼀个函数映射到⼀个输⼊列表的所有元素上。这是它的规范&#xff1a;规范 map(function_to_apply, list_of_inputs) ⼤多数时候&#xff0c;我们要把列表中所有元素⼀个个地传递给⼀个函数&a…

JavaFX动画工具

好的&#xff0c;我想是时候让您讲一个小秘密了。 在过去的大约三个月中&#xff0c;我从事一个私有项目&#xff0c;目标是创建一个工具&#xff0c;使我可以轻松地为Java桌面应用程序创建动画。 JavaFX在API级别上提供了出色的动画制作支持&#xff0c;但对于初学者甚至中级程…

ImageWatch的使用

1.能够实时显示图像和矩阵Mat的内容&#xff0c;跟Matlab很像&#xff0c;方便程序调试&#xff0c;相当好用。 下载地址&#xff1a; https://marketplace.visualstudio.com/items?itemNameVisualCPPTeam.ImageWatch 2.下载好插件ImageWatch&#xff0c;双击ImageWatch.vs…

springboot与任务(邮件任务)

邮件发送需要引入spring-boot-starter-mailSpring Boot 自动配置MailSenderAutoConfiguration定义MailProperties内容&#xff0c;配置在application.yml中自动装配JavaMailSender 测试邮件发送 pom文件配置&#xff1a; <!--邮件发送--><dependency><groupId&g…

具有ESB,API管理和Now ..服务网格的应用程序网络功能。

我最近谈论了微服务模式的演变&#xff0c;以及来自Lyft的Envoy之类的服务代理如何帮助将弹性&#xff0c;服务发现&#xff0c;路由&#xff0c;指标收集等责任推到应用程序下一层。 否则&#xff0c;我们冒着希望并祈祷各种应用程序将正确实现这些关键功能或依赖于特定语言的…

宝塔定时任务执行php源码任务_Linux at命令详解:定时执行任务

要想使用 at 命令&#xff0c;读者需提前安装好 at 软件包&#xff0c;并开启 atd 服务。因此&#xff0c;首先来看看如何安装 at 软件包。在 Linux 系统中&#xff0c;查看 at 软件包是否已安装&#xff0c;可以使用 rpm -q 命令&#xff0c;如下所示&#xff1a;[rootlocalho…

Eigen(1)配置VS2015

1.在Eigen官网下载Eigen&#xff1a; Windows选压缩包zip下载&#xff0c;点击一下即可。下载后解压。 2.配置VS2015 打开vs2013&#xff0c;可以新建一个项目&#xff0c;也可以打开以前的项目&#xff0c;右键项目名&#xff0c;选择属性&#xff0c;在c/c附加目录里加入解压…

尺度不变性是指什么不变_不变性的来龙去脉

尺度不变性是指什么不变因此&#xff0c;在我的第一篇文章中&#xff0c;我谈到了一些构建器模式&#xff0c;并提到了一个非常强大但却被忽视的概念&#xff1a;不变性。 什么是不可变类&#xff1f; 这只是一个其实例无法修改的类。 类属性的每个值都在其声明或其构造函数中…

光模块

一、光模块&#xff1a; 1、光模块&#xff08;opTIcalmodule&#xff09;由光电子器件、功能电路和光接口等组成&#xff0c;光电子器件包括发射和接收两部分。 发射部分是&#xff1a;输入一定码率的电信号经内部的驱动芯片处理后驱动半导体激光器&#xff08;LD&#xff09;…

radmin提示授权码过期_IdentityServer4 客户端授权模式(Client Credentials)

(给DotNet加星标&#xff0c;提升.Net技能)转自&#xff1a;朝闲cnblogs.com/Zing/p/13361386.html前言1、源码(.NET Core 2.2)git地址&#xff1a;https://github.com/yizhaoxian/CoreIdentityServer4Demo.git2、相关章节2.1、《IdentityServer4 (1) 客户端授权模式(Client Cr…

OpenCV访问像素点的灰度值

1.Mat矩阵数值的存储方式 这里以指针的方式访问图像素为例 (1)单通道 定义一个单通道图像&#xff1a; cv::Mat img_1 (320, 640, CV_8UC1, Scalar(0)); 对于单通道M(i,j)即为第i行j列的其灰度值&#xff1b;程序中表示为&#xff1a; img_1.ptr<uchar>(i)[j]; (2)多通道…

asp.net中大文件下载

因为IIS支持的最大文件为int32的最大值位数的文件下载&#xff0c;所以&#xff0c;超过2G的文件无法通过IIS进行下载。 通过网上查找的资料&#xff0c;如下可实现文件的下载&#xff0c;使用filestream进行下载。 public void download(){System.IO.Stream iStream null;byt…

Java的终结器仍然存在

当我第一次学习Java并从C 过渡到Java时&#xff0c;我记得我经常被告知&#xff0c;经常读到它不应该像C 析构函数那样对待Java终结器&#xff0c;也不应该依靠它。 该建议的频率和坚持性对我产生了影响&#xff0c;以至于我无法回忆起我上一次编写finalize&#xff08;&#x…

时隙aloha协议仿真程序_工控ModbusTCP/IP协议仿真环境搭建

01ModbusTCP/IP协议简介Modbus TCP/IP是简单的、中立厂商的用于管理和控制自动化设备的MODBUS系列通讯协议的派生产品。它覆盖了使用TCP/IP协议的“intranet”和“internet”环境中MODBUS报文的用途。协议的最通用用途是为诸如PLC’S&#xff0c;I/O模块&#xff0c;以及连接其…

vector的初始化及常用操作

1.vector的初始化&#xff1a;可以有五种方式,举例说明如下&#xff1a; &#xff08;1&#xff09; vector<int> a(10); //定义了10个整型元素的向量&#xff08;尖括号中为元素类型名&#xff0c;它可以是任何合法的数据类型&#xff09;&#xff0c;但没有给出初值&a…

查看Linux版本

suse版本 lsb_release -a suse版本之间差距还是有的&#xff0c;在suse12.2跑的脚本没有问题&#xff0c;到suse12.4上就出现问题了。 centos版本 cat /etc/redhat-release 转载于:https://www.cnblogs.com/jkhere/p/10900659.html

ps法线贴图插件_法线与置换贴图原理讲解以及烘焙制作!

​首先在讲解之前先给大家讲解下什么是法线贴图&#xff0c;法线贴图其实就是一张带有颜色的凹凸贴图&#xff0c;分别是有红绿蓝&#xff0c;三种颜色构造而成的&#xff0c;如下图所示&#xff1a;每一个颜色通道分别控制了每个像素的方向&#xff0c;当你把法线贴图用到低解…

从向量中读取元素:

从向量中读取元素&#xff1a; 1通过下标&#xff1a; int a[6] { 1,2,3,4,5,6 }; vector<int> b(a, a 4); for (int i 0; i < b.size() - 1; i) cout << b[i] << " "; 2通过迭代器 int a[6] { 1,2,3,4,5,6 }; vector<int> b(a, …

Nim博弈

忽然发现博弈论是个很好玩的东西哎 之前假期学长讲课的时候就发现这种必胜的战略可以用来坑人做题 这两天终于做了第一道博弈论的题&#xff0c;写篇博客纪念一下 灵感来源&#xff1a;洛谷P1247 Pre-scene 众所周知&#xff0c;李明和Jenny都喜欢Danny&#xff0c;为了争夺Dan…

java调用怎么调用方法区_Java中的方法调用有多昂贵

java调用怎么调用方法区我们都去过那儿。 在查看设计不良的代码的同时&#xff0c;听听作者对人们永远不应该牺牲性能而不是设计的解释。 而且&#xff0c;您不能说服作者摆脱其500行方法&#xff0c;因为链接方法调用会破坏性能。 好吧&#xff0c;这可能在1996年左右是正确的…