自深深处

用自我批判的精神来学习~

编译原理的词法分析含界面和源码

原谅我不修边幅的排版

IDE:myeclpise
java语言实现类C词法分析,含界面(SWING),源码运行无误。

/*
目录:
这里写图片描述
结果:

这里写图片描述

*/
/*
内容:
给定字母表{0,1,…9,a,b…z,A,B,…Z},定义其上的正规定义式如下:
Digit →1|2|…|9
Num →0|Digit
Letter→a|b|…|z|A|B|…|Z
原语言中允许出现的词由如下正规式规定(本语言不区分字母大小写,即认为大小写相同):
var|integer|longint|bool|If|Then|Else|While|Do|For
|Begin|End|and| or| +|-|*|/|:=|<|>|<>|>=|<=|= =|;
|:|(|)|,|Digit·Num*|Letter·(Letter|Num)*
给出识别该语言的词法分析程序,正确程序示例如下:
Var i,J1:integer; (表示整型,假定用1个字节存储)
Sum:longint; (表示长整型,假定用两个字节存储)
FLAG:bool;
定义体部分,一段程序必须有定义体部分。定义体关键字为var其后跟一个或多个空格与被定义变量分隔。逗号用来分割定义体中被定义变量,最后一个被声明变量后跟:与变量类型关键字分割。上面程序也可以写作
Var i,j:integer;Sum:real;flag:bool;
因此,用;来分割程序行,而不一定要实际换行。
定义体的错误示例如下:
Vari:integer; —–Var后缺空格
Var 9I:integer; —–变量以数字开头
Var i j:integer; —–多变量缺分割符或变量中有非法空格
Var i#:integer; —–变量含非法字符
Var i3:integer —–缺;
Flag:bool;
Var i3:integer;
I3:bool; —–变量重复定义
等等…。
分割定义体和实现体的关键词为begin,在begin之前的均分析为定义体,之后均分析为实现体。
实现体正确示例(假定前面的正确定义体已经给出):
Begin
i:=0;
J1:=50;
Sum:=1;
FLAG:=1;
While(i

源码下载:

https://download.csdn.net/download/zzy123zzy123_/10477781

实验报告:

https://download.csdn.net/download/zzy123zzy123_/10477794

实验内容:

参见资源库,但无下载必要,主要参考上述即可。源码运行无误。

阅读更多
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/zzy123zzy123_/article/details/80687493
文章标签: bianyiyuanli
个人分类: bianyiyuanli
想对作者说点什么? 我来说一句

C语言词法分析器(Java版.带界面)

2009年11月06日 738KB 下载

词法分析器(简单界面

2013年04月23日 8KB 下载

可视化词法分析

2013年05月19日 80KB 下载

没有更多推荐了,返回首页

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭