语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc

上传人:b****1 文档编号:13195988 上传时间:2022-10-08 格式:DOC 页数:22 大小:685KB
下载 相关 举报
语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc_第1页
第1页 / 共22页
语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc_第2页
第2页 / 共22页
语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc_第3页
第3页 / 共22页
语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc_第4页
第4页 / 共22页
语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc_第5页
第5页 / 共22页
点击查看更多>>
下载资源
资源描述

语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc

《语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc》由会员分享,可在线阅读,更多相关《语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc(22页珍藏版)》请在冰豆网上搜索。

语义分析及中间代码生成程序设计原理与实现技术--实验报告及源代码-北京交通大学Word文档格式.doc

charleft;

vector<

string>

right;

char>

first;

last;

};

算符优先矩阵采用二维字符数组表示的:

charmtr[9][9];

//算符优先矩阵

4.程序结构描述:

本程序一共有8功能函数:

voidget();

//获取文法

voidprint();

//打印文法

voidfun();

//求FirstVT和LastVT

voidmatrix();

//求算符优先矩阵

voidtest();

//测试文法

intcmp(chara,charb);

比较两个运算符的优先级10-1

voidout(charnow,intavg1,intavg2);

//打印四元式

intope(charop,inta,intb);

//定义四元式计算方法

5.实验代码

详见附件

6.程序测试

6.1功能测试

程序运行显示如下功能菜单:

选择打印文法:

选择构造FirstVt集和LastVT集:

选择构造算符优先矩阵:

6.2文法测试

测试1:

1+2*3

测试2:

2+3+4*5+(6/2)

7.学习总结

本次实验完成了语义及中间代码生成的设计原理与实现,所采用的方法为算符优先分析方法,首先根据文法求出此文法的FirstVT集和LastVT集,然后根据他们求出此文法的算符优先矩阵。

由于此文法和第四次文法基本相同,只是多了一条赋值语句,所以采用的规则和第四次基本相同。

在分析阶段,每当遇到有规约的项目,判断一下,打印出此部运算的四元式,这样一步一步分析,知道输入的算术表达式计算分析完毕。

由于本次实验部分代码和第四次实验的代码比较相似,只需增加一点四元式的分析计算打印过程,就能够顺利完成本次实验。

通过这次实验,我对语义分析以及中间代码部分有了一定的提高,对以后的学习有了一定程度上的帮助。

//lb6.cpp:

定义控制台应用程序的入口点。

//

#include"

stdafx.h"

#include<

iostream>

VECTOR>

stack>

usingnamespacestd;

vector<

info>

lang;

stack<

sta;

//比较两个运算符的优先级10-1

//打印四元式

//定义四元式计算方法

intmain(){

intchoose;

while

(1){

cout<

<

"

****************************************"

<

endl;

获取文法请按1"

<

打印文法请按2"

构造FirstVT集和LastVT集请按3"

构造优先关系矩阵请按4"

文法测试请按5"

结束请按0"

cin>

>

choose;

if(choose==0)

break;

switch(choose){

case1:

get();

break;

case2:

print();

break;

case3:

fun();

case4:

matrix();

break;

case5:

test();

break;

default:

break;

}

}

return0;

}

voidget(){

infotemp,temp1,temp2;

temp.left='

E'

;

temp.right.push_back("

E+T"

);

E-T"

T"

i"

temp1.left='

T'

temp1.right.push_back("

T*F"

T/F"

F"

temp2.left='

F'

temp2.right.push_back("

(E)"

lang.push_back(temp);

lang.push_back(temp1);

lang.push_back(temp2);

cout<

文法获取完成"

<

voidprint(){

for(inti=0;

i<

lang.size();

i++){

for(intj=0;

j<

lang[i].right.size();

j++){

cout<

lang[i].left<

-->

lang[i].right[j]<

voidfun(){

inti,j,sign=0,sign1=0;

for(i=0;

for(j=0;

stringtemp=lang[i].right[j];

//获取右部

if(temp[0]>

'

Z'

||temp[0]<

A'

){//终结符

lang[i].first.push_back(temp[0]);

}

elseif(temp.length()>

=2){//终结符

if(temp[1]>

||temp[1]<

){

lang[i].first.push_back(temp[1]);

}

if((temp[0]>

)&

&

temp.length()==1){//终结符

lang[i].last.push_back(temp[0]);

=3){//终结符

lang[i].last.push_back(temp[1]);

elseif(temp[2]>

||temp[2]<

)//终结符

lang[i].last.push_back(temp[2]);

while(sign==0){//迭代FirstVT

sign=1;

for(i=0;

for(j=0;

stringtemp=lang[i].right[j];

if(temp.length()==1&

(temp[0]<

='

&

temp[0]>

)){//可以迭代

for(intk=0;

k<

k++){

if(lang[k].left==temp[0]){//找到了,添加元素

for(intp=0;

p<

lang[k].first.s

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 幼儿教育 > 育儿理论经验

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1