- 1、本文档共14页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
小型编译程序的词法设计与实现
本实验设计的小型编译程序涉及到编译前端的三个阶段:词法分析、语法分析和语义分析生成中间代码(四元式),编译程序的重点放在中间代码生成阶段。编译程序的输出结果包括词法分析后的二元式序列、变量名表;语法分析后的状态栈分析过程显示;语义分析生成中间代码后的四元式程序。整个程序分为三个部分:
(1) 词法分析部分
(2) 语法分析、语义分析及四元式生成部分
(3) 输出显示部分
词法分析器设计
词法分析器的功能是输入源程序,输出单词符号。我们规定输出的单词符号格式为如下的二元式:
(单词种别编码,单词自身的值)
由于我们规定的程序语句中涉及单词较少,故在词法分析阶段忽略了单词输入错误的检查。
1.1 单词符号的内部定义及在编译程序中的定义
我们对常量、变量、临时变量、保留关键字(if、while、begin、end、else、then、do等)、关系运算符、逻辑运算符、分号、括号等,规定其内部定义如下:
符 号
种别编码
说 明
sy_if
0
保留字 if
sy_then
1
保留字 then
sy_else
2
保留字 else
sy_while
3
保留字 while
sy_begin
4
保留字 begin
sy_do
5
保留字 do
sy_end
6
保留字 end
a
7
赋值语句
semicolon
8
“ ; ”
e
9
布尔表达式
Jinghao
10
“ # ”
S
11
语句
L
12
复合语句
Tempsy
15
临时变量
EA
18
B and(即布尔表达式中的B∧)
EO
19
B or(即布尔表达式中的B∨ )
Plus
34
“ + ”
Times
36
“ * ”
Becomes
38
“ := ” 赋值
Op_and
39
“ and ”
Op_or
40
“ or ”
Op_not
41
“ not ”
Rop
42
关系运算符
Lparent
48
“ ( ”
Rparent
49
“ ) ”
Ident
56
变量
Intconst
57
整常量
#define sy_if 0
#define sy_then 1
#define sy_else 2
#define sy_while 3
#define sy_begin 4
#define sy_do 5
#define sy_end 6
#define a 7
#define semicolon 8
#define e 9
#define jinghao 10
#define S 11
#define L 12
#define tempsy 15
#define EA 18 /*E and*/
#define E0 19 /E or*/
#define plus 34
#define times 36
#define becomes 38
#define op_and 39
#define op_or 40
#define op_not 41
#define rop 42
#define lparent 48
#define rparent 49
#define ident 56
#define intconst 57
1.2 变量及数据结构说明
编译程序中涉及到的变量及数据结构说明如下:
char ch=\0; /*从字符缓冲区读取当前字符*/
int count=0; /*词法分析结果缓冲区计数器*/
static char spelling[10]={}; /*存放识别的字*/
static char line[81]={}; /*一行字符缓冲区,最多80个字符*/
char *pline; /*字符缓冲区指针*/
static char ntab1[100][10]; /*变量名表,共100项,每项长度10*/
struct rwords{
char sp[10];
int sy;
}; /*保留字表的结构,用来与输入缓冲区中的单词进行匹配*/
struct rwords reswords[10]={{if,sy_if},
{do,sy_do},
{else,sy_else},
{while
您可能关注的文档
- 计划生育服务工作 重要性.ppt
- 计算方法-实验三列主元高斯消去法.doc
- 计算机一级B课件(完整版) .ppt
- 计算机专业实习报告范文大全(共18篇42页) .doc
- 计划并行动直到达成目标—与成功有约.doc
- 计算机国家三级考试上机题库最终修订版100.doc
- 计算机在线考试系统项目总结.doc
- 计划生育家庭意外伤害保险.ppt
- 计算机原理及应用课程考试说明.doc
- 计算机四级网络工程师第一章网络及其系统设计.ppt
- 五位一体教案教学教案设计.docx
- 思修与法基-教学教案分享.pptx
- 大学军事之《中国国防》题库分享.docx
- 2023版毛泽东思想和中国特色社会主义理论体系概论第五章-中国特色社会主义理论体系的形成发展.pdf
- 思修与法基 教学全案分享.docx
- 大学军事之《军事思想》题库分享.docx
- 《经济思想史》全套课件-国家级精品课程教案课件讲义分享.pdf
- 厦门大学国际金融全套资料(国家级精品课程)--全套课件.pdf
- 2023版毛泽东思想和中国特色社会主义理论体系概论第五章-中国特色社会主义理论体系的形成发展.docx
- 2023版毛泽东思想和中国特色社会主义理论体系概论第五章中国特色社会主义理论体系的形成发展分享.pdf
文档评论(0)