编译原理-简单编译器课程设计报告
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
}
syn=24;
break;
case '/':
syn=25;
token[m++]=ch;
break;
case '(':
temp2=prog[p];
token[m++]=ch;
if(temp2=='+')
{
isSignal=2;
repeat=1;
}
else if(temp2=='-')
{
isSignal=1;
表
格
管
理
出
错
处
理
单词符号
语法单元
中间代码
中间代码
目标代码
语法分析器
语义分析与中间代码生成器
优化器
目标代码生成器
词法分析器
下图给出了编译系统的结构框 图
二、总体设计方案及主要设计原理
、单词符号及种别表示
单词符号
种别编码
单词值
main
1
int
2
float
3
double
4
char
5
if
6
else
7
do
8
while
2011-12-11—16
查找资料
理清思路,编写程序
完善程序,编辑文档
参考文献、资料索引
序号
文献、资料名称
编著者
出版单位
【1】程序设计语言编译原理陈火旺 李春林国防工业出版社
【2】数据结构严蔚敏清华大学出版社
【3】C++程序设计吴乃林 况迎辉高等教育出版社
【4】C语言程序设计谭浩强清华大学出版社
【5】程序设计语言编译原理陈火旺、刘春林等国防工业出版社
通过实践,我发现自身还有许多不足之处,我深刻认识到要学好计算机必须重视实践,所以在以后的学习过程中,我会更加注视上机操作,使自己更好地学好专业知识。回顾此次编译原理课程设计,可以说得是苦多于甜,但是我在巩固了以前所学过知识的同时,也学到了很多在已开设课程中未学到的知识。只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正提高自己的实际动手能力和独立思考的能力。
strcpy(fourCom[nextq].opera,op);
strcpy(fourCom[nextq].arg2,num2);
nextq++;
}
void scanner()
{
sum=0;
decimal=0;
m=0;
for(n=0;n<8;n++)
token[n]=NULL;
ch=prog[p++];
、语法分析主要思想
这部分对Token链进行分析,利用自底向上的分析方法,构建SLR(1)分析表的过程是手工完成的。语法分析的同时构建语法树,移进时创建叶子,规约时创建节点。
、语义分析主要分析
这部分对语法树从左到右进行遍历,节点记录了规约式的编号,遍历到节点时就进行相应处理。语义分析主要检查变量、函数是否被定义或重定义,同时产生四元式。
信息科学与工程学院课程设计任务书
题目:一个简单编译器的设计与分析
姓 名:
学 号:
专业班级:
课 程:编译原理
指导教师:职称:讲 师
完成时间: 2011年12月----2011年12月
枣庄学院信息科学与工程学院制
2011年12月20日
课程设计任务书及成绩评定
课程设计的任务和具体要求
在理解编译原理相关理论的基础上,要求用C或C++语言描述及上机调试,实现一个小编译器(包括符号表的构造,词法分析,语法分析,语义分析,目标代码生成等重要子程序,其中词法分析、语法分析及语义分析功能必须完成),使学生将理论与实际应用结合起来,受到软件设计等开发过程的全面训练,从而提高学生软件开发的能力。
{
isDecimal=1;
ch=prog[p++];
count=0; //之前忘了清零,+#两个浮点数就无法识别
while((ch>='0')&&(ch<='9'))
{
//pow(x,y)计算x的y次幂
temp=(ch-'0')*pow,++count);
decimal=decimal+temp;
//AddToDec();
isSignal=0;
}
p--;
syn=20;
}
else switch(ch)
{
case '<':
m=0;
token[m++]=ch;
ch=prog[p++];
if(ch=='=')
{
syn=35;
token[m++]=ch;
}
else
{
syn=34;
p--;
}
break;
case '>':
m=0;
repeat=1;
}
syn=26;
break;
case ')':
syn=27;
token[m++]=ch;
break;
case '{':
syn=28;
token[m++]=ch;
break;
case '}':
syn=29;
token[m++]=ch;
break;
case ',':
syn=30;
token[m++]=ch;
ch=prog[p++];
}
sum=sum+decimal;
}
if(ch=='e'||ch=='E')
{
isExp=1;
ch=prog[p++];
if(ch=='-')
{
isNegative=1;
ch=prog[p++];
}
while((ch>='0')&&(ch<='9'))
{
//指数
index=index*10+ch-'0';
}
else
{
syn=21;
p--;
}
break;
case '+':
temp2=prog[p];
பைடு நூலகம்token[m++]=ch;
if((temp2>='0')&&(temp2<='9')&&(repeat==1))
{
isSignal=2;
ch=prog[p++];
repeat=0;
goto IsNum;
}
ch=prog[p++];
}
//10的幂
//123e3代表123*10(3)
//sum=sum*pow(10,index);是错误的
if(isNegative)
sum=sum*pow,index);
else
sum=sum*pow(10,index);
}
if(isSignal==1)
{
sum=-sum;
9
l(l|d)*
10
内部字符串
( +|-|ε) d*(.dd* |ε)( e ( +|-|ε) dd*|ε)
20
二进制数值表示
=
21
+
22
-
23
*
24
/
25
(
26
)
27
{
28
}
29
,
30
;
31
>
32
>=
33
<
34
<=
35
==
36
!=
37
、语法结构定义
<程序> ::=main()<语句块>
<语句块> ::= ‘{‘<语句串>’}’字数字*|ε)( e ( +|-|ε)数字数字*|ε)
一、摘要
编译程序的工作过程一般可以分为五个阶段:词法分析、语法分析、语义分析与中间代码产生、优化、目标代码生成。每一个阶段在功能上是相对独立的,它一方面从上一个阶段获取分析的结果来进行分析,另一方面由将结果传递给下一个阶段。由编译程序的五个阶段就对应了编译系统的结构。
其中词法分析器利用超前搜索、状态转换等方法,将源程序转化成为一个一个的单词符号二元式。一般程序语言的单词符号包括关键字、运算符、常数、标识符和界符。语法分析器将这些单词符号作为输入,对它进行语法分析。语法分析分为两种方法:自上而下分析法和自下而上分析法。针对不同程序语言的语法规则可以采取不同的分析方法,当然两种方法也可以同时使用。语法分析器把语法单元作为输入供语义分析器使用。一般的语义分析器主要采用的是语法制导方法,即在语法分析的同时进行语法分析,并产生一定的语义动作,来生成中间代码。上面三个过程可以与硬件无关,而接下来的优化器和目标代码生成器是针对某一种处理器而言的。代码优化是将语义分析生成的中间代码进行优化,产生执行效率更高的代码。目标代码生成器最终生成可以在某种机器上运行的机器语言或者汇编语言。在整个编译过程中还包括对表格的操作和对错误的处理,这些也都是非常重要的环节。
三、源程序代码
#include<>
#include<>
#include<>
#include<>
char prog[80];rg1,fourCom[i].opera,fourCom[i].arg2,fourCom[i].result);
}
}
void lrparser()
{
int nChain;
nfc=ntc=1;
if(((temp2=='+')||(temp2=='-'))&&(repeat==0)) //如果重复出现符号,才将后边的+,-视为正负号
{
repeat=1;
//ch=prog[p++];
}
syn=22;
break;
case '-':
temp2=prog[p];
token[m++]=ch;
if((temp2>='0')&&(temp2<='9')&&(repeat==1))
nextq=1;
if(syn==1)esult); esult,t);esult,"%d",t);
circle=w; esult))esult);
esult,p1);
sprintf(fourCom[circle].result,"%s",p1);
}
esult,res);
strcpy(fourCom[nextq].arg1,num1);
//ch=prog[p++]; //读下一个字符
}
syn=23;
break;
case '*':
temp2=prog[p];
token[m++]=ch;
if(temp2=='+')
{
isSignal=2;
repeat=1;
}
else if(temp2=='-')
{
isSignal=1;
repeat=1;
token[m++]=ch;
ch=prog[p++];
if(ch=='=')
{
syn=33;
token[m++]=ch;
}
else
{
syn=32;
p--;
}
break;
case '=':
m=0;
token[m++]=ch;
ch=prog[p++];
if(ch=='=')
{
syn=36;
token[m++]=ch;
指导教师签字:_______ 日期:
指导教师评语
成绩:____________指导教师签字:日期:
课程设计所需软件、硬件等
硬件环境:WindowsXP/Win7操作系统
软件环境:MicrosoftvisualC++
课程设计进度计划
起至日期
工作内容
备注
2011-12-01—05
2011-12-06—10
break;
case ';':
syn=31;
token[m++]=ch;
break;
case'#':
syn=0;
token[m++]=ch;
break;
default:
syn=-1;
}
}
四、测试及分析
运行程序,结果如下:
先输入正确的程序
再输入错误的程序
五、心得体会
本次编译原理词法分析器的系统开发使我对词法分析有了进一步的认识,也对编译原理这门课程的了解更加深入,要想学好它重在实践。通过此次手动构造词法分析,我认识到做程序设计并不是只掌握词法分析的思想和方法就够的,一定得自己动手,这样才能充分认识到自己的不足,以提高自己的设计能力。
{
isSignal=1;
ch=prog[p++]; //读“-”下一个字符
repeat=0;
goto IsNum; //转到数字的识别
}
if(((temp2=='+')||(temp2=='-'))&&(repeat==0)) //如果重复出现符号,才将后边的+,-视为正负号
{
repeat=1; //预言会重复
ID::=字母(字母|d数字)*
字母::=a|b|c…|z|A|B|C…|Z
数字::=0|1|2…|9
<关系运算符> ::=<|<=|>|>=|==|!=
、主要算法
、词法分析主要算法
这部分对源文件进行分析,允许/* */注释。从源文件依次读取字符,对字符进行分析,组成字符串、数字、关系符等固定含义的token符,并把它们添加到token链中,如果遇到非法字符报错并退出程序。
syn=24;
break;
case '/':
syn=25;
token[m++]=ch;
break;
case '(':
temp2=prog[p];
token[m++]=ch;
if(temp2=='+')
{
isSignal=2;
repeat=1;
}
else if(temp2=='-')
{
isSignal=1;
表
格
管
理
出
错
处
理
单词符号
语法单元
中间代码
中间代码
目标代码
语法分析器
语义分析与中间代码生成器
优化器
目标代码生成器
词法分析器
下图给出了编译系统的结构框 图
二、总体设计方案及主要设计原理
、单词符号及种别表示
单词符号
种别编码
单词值
main
1
int
2
float
3
double
4
char
5
if
6
else
7
do
8
while
2011-12-11—16
查找资料
理清思路,编写程序
完善程序,编辑文档
参考文献、资料索引
序号
文献、资料名称
编著者
出版单位
【1】程序设计语言编译原理陈火旺 李春林国防工业出版社
【2】数据结构严蔚敏清华大学出版社
【3】C++程序设计吴乃林 况迎辉高等教育出版社
【4】C语言程序设计谭浩强清华大学出版社
【5】程序设计语言编译原理陈火旺、刘春林等国防工业出版社
通过实践,我发现自身还有许多不足之处,我深刻认识到要学好计算机必须重视实践,所以在以后的学习过程中,我会更加注视上机操作,使自己更好地学好专业知识。回顾此次编译原理课程设计,可以说得是苦多于甜,但是我在巩固了以前所学过知识的同时,也学到了很多在已开设课程中未学到的知识。只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正提高自己的实际动手能力和独立思考的能力。
strcpy(fourCom[nextq].opera,op);
strcpy(fourCom[nextq].arg2,num2);
nextq++;
}
void scanner()
{
sum=0;
decimal=0;
m=0;
for(n=0;n<8;n++)
token[n]=NULL;
ch=prog[p++];
、语法分析主要思想
这部分对Token链进行分析,利用自底向上的分析方法,构建SLR(1)分析表的过程是手工完成的。语法分析的同时构建语法树,移进时创建叶子,规约时创建节点。
、语义分析主要分析
这部分对语法树从左到右进行遍历,节点记录了规约式的编号,遍历到节点时就进行相应处理。语义分析主要检查变量、函数是否被定义或重定义,同时产生四元式。
信息科学与工程学院课程设计任务书
题目:一个简单编译器的设计与分析
姓 名:
学 号:
专业班级:
课 程:编译原理
指导教师:职称:讲 师
完成时间: 2011年12月----2011年12月
枣庄学院信息科学与工程学院制
2011年12月20日
课程设计任务书及成绩评定
课程设计的任务和具体要求
在理解编译原理相关理论的基础上,要求用C或C++语言描述及上机调试,实现一个小编译器(包括符号表的构造,词法分析,语法分析,语义分析,目标代码生成等重要子程序,其中词法分析、语法分析及语义分析功能必须完成),使学生将理论与实际应用结合起来,受到软件设计等开发过程的全面训练,从而提高学生软件开发的能力。
{
isDecimal=1;
ch=prog[p++];
count=0; //之前忘了清零,+#两个浮点数就无法识别
while((ch>='0')&&(ch<='9'))
{
//pow(x,y)计算x的y次幂
temp=(ch-'0')*pow,++count);
decimal=decimal+temp;
//AddToDec();
isSignal=0;
}
p--;
syn=20;
}
else switch(ch)
{
case '<':
m=0;
token[m++]=ch;
ch=prog[p++];
if(ch=='=')
{
syn=35;
token[m++]=ch;
}
else
{
syn=34;
p--;
}
break;
case '>':
m=0;
repeat=1;
}
syn=26;
break;
case ')':
syn=27;
token[m++]=ch;
break;
case '{':
syn=28;
token[m++]=ch;
break;
case '}':
syn=29;
token[m++]=ch;
break;
case ',':
syn=30;
token[m++]=ch;
ch=prog[p++];
}
sum=sum+decimal;
}
if(ch=='e'||ch=='E')
{
isExp=1;
ch=prog[p++];
if(ch=='-')
{
isNegative=1;
ch=prog[p++];
}
while((ch>='0')&&(ch<='9'))
{
//指数
index=index*10+ch-'0';
}
else
{
syn=21;
p--;
}
break;
case '+':
temp2=prog[p];
பைடு நூலகம்token[m++]=ch;
if((temp2>='0')&&(temp2<='9')&&(repeat==1))
{
isSignal=2;
ch=prog[p++];
repeat=0;
goto IsNum;
}
ch=prog[p++];
}
//10的幂
//123e3代表123*10(3)
//sum=sum*pow(10,index);是错误的
if(isNegative)
sum=sum*pow,index);
else
sum=sum*pow(10,index);
}
if(isSignal==1)
{
sum=-sum;
9
l(l|d)*
10
内部字符串
( +|-|ε) d*(.dd* |ε)( e ( +|-|ε) dd*|ε)
20
二进制数值表示
=
21
+
22
-
23
*
24
/
25
(
26
)
27
{
28
}
29
,
30
;
31
>
32
>=
33
<
34
<=
35
==
36
!=
37
、语法结构定义
<程序> ::=main()<语句块>
<语句块> ::= ‘{‘<语句串>’}’字数字*|ε)( e ( +|-|ε)数字数字*|ε)
一、摘要
编译程序的工作过程一般可以分为五个阶段:词法分析、语法分析、语义分析与中间代码产生、优化、目标代码生成。每一个阶段在功能上是相对独立的,它一方面从上一个阶段获取分析的结果来进行分析,另一方面由将结果传递给下一个阶段。由编译程序的五个阶段就对应了编译系统的结构。
其中词法分析器利用超前搜索、状态转换等方法,将源程序转化成为一个一个的单词符号二元式。一般程序语言的单词符号包括关键字、运算符、常数、标识符和界符。语法分析器将这些单词符号作为输入,对它进行语法分析。语法分析分为两种方法:自上而下分析法和自下而上分析法。针对不同程序语言的语法规则可以采取不同的分析方法,当然两种方法也可以同时使用。语法分析器把语法单元作为输入供语义分析器使用。一般的语义分析器主要采用的是语法制导方法,即在语法分析的同时进行语法分析,并产生一定的语义动作,来生成中间代码。上面三个过程可以与硬件无关,而接下来的优化器和目标代码生成器是针对某一种处理器而言的。代码优化是将语义分析生成的中间代码进行优化,产生执行效率更高的代码。目标代码生成器最终生成可以在某种机器上运行的机器语言或者汇编语言。在整个编译过程中还包括对表格的操作和对错误的处理,这些也都是非常重要的环节。
三、源程序代码
#include<>
#include<>
#include<>
#include<>
char prog[80];rg1,fourCom[i].opera,fourCom[i].arg2,fourCom[i].result);
}
}
void lrparser()
{
int nChain;
nfc=ntc=1;
if(((temp2=='+')||(temp2=='-'))&&(repeat==0)) //如果重复出现符号,才将后边的+,-视为正负号
{
repeat=1;
//ch=prog[p++];
}
syn=22;
break;
case '-':
temp2=prog[p];
token[m++]=ch;
if((temp2>='0')&&(temp2<='9')&&(repeat==1))
nextq=1;
if(syn==1)esult); esult,t);esult,"%d",t);
circle=w; esult))esult);
esult,p1);
sprintf(fourCom[circle].result,"%s",p1);
}
esult,res);
strcpy(fourCom[nextq].arg1,num1);
//ch=prog[p++]; //读下一个字符
}
syn=23;
break;
case '*':
temp2=prog[p];
token[m++]=ch;
if(temp2=='+')
{
isSignal=2;
repeat=1;
}
else if(temp2=='-')
{
isSignal=1;
repeat=1;
token[m++]=ch;
ch=prog[p++];
if(ch=='=')
{
syn=33;
token[m++]=ch;
}
else
{
syn=32;
p--;
}
break;
case '=':
m=0;
token[m++]=ch;
ch=prog[p++];
if(ch=='=')
{
syn=36;
token[m++]=ch;
指导教师签字:_______ 日期:
指导教师评语
成绩:____________指导教师签字:日期:
课程设计所需软件、硬件等
硬件环境:WindowsXP/Win7操作系统
软件环境:MicrosoftvisualC++
课程设计进度计划
起至日期
工作内容
备注
2011-12-01—05
2011-12-06—10
break;
case ';':
syn=31;
token[m++]=ch;
break;
case'#':
syn=0;
token[m++]=ch;
break;
default:
syn=-1;
}
}
四、测试及分析
运行程序,结果如下:
先输入正确的程序
再输入错误的程序
五、心得体会
本次编译原理词法分析器的系统开发使我对词法分析有了进一步的认识,也对编译原理这门课程的了解更加深入,要想学好它重在实践。通过此次手动构造词法分析,我认识到做程序设计并不是只掌握词法分析的思想和方法就够的,一定得自己动手,这样才能充分认识到自己的不足,以提高自己的设计能力。
{
isSignal=1;
ch=prog[p++]; //读“-”下一个字符
repeat=0;
goto IsNum; //转到数字的识别
}
if(((temp2=='+')||(temp2=='-'))&&(repeat==0)) //如果重复出现符号,才将后边的+,-视为正负号
{
repeat=1; //预言会重复
ID::=字母(字母|d数字)*
字母::=a|b|c…|z|A|B|C…|Z
数字::=0|1|2…|9
<关系运算符> ::=<|<=|>|>=|==|!=
、主要算法
、词法分析主要算法
这部分对源文件进行分析,允许/* */注释。从源文件依次读取字符,对字符进行分析,组成字符串、数字、关系符等固定含义的token符,并把它们添加到token链中,如果遇到非法字符报错并退出程序。