编译原理实验作业

该实验作业详述了如何在Ubuntu环境下,利用flex和yacc工具开发一个简单的计算器程序。实验内容包括编写解析文法的demo.y文件和处理词法的demo.l文件,然后通过flex和yacc生成C代码并用gcc编译成可执行程序。
摘要由CSDN通过智能技术生成

demo实验说明书

实验环境:

  • 操作系统:Ubuntu(1604及以上)
  • 软件:flex, yacc, gcc(安装:sudo apt install flex yacc gcc -y)

实验内容:

演示一个利用flex和yacc工具实现的计算器程序。

实验步骤:

  1. 编写demo.y文件,包含计算器的文法及语义信息。
%{
/* Definition section */
#include <stdio.h>
#include <stdlib.h>
int yylex(void);
void yyerror(const char * msg);
%}

%token NUMBER

%left '+' '-'

%left '*' '/' '%'

%left '(' ')'

%nonassoc UMINUS
/* Rule Section */
%%

ArithmeticExpression: E{
	printf("Result=%d\n", $$);
	return 0;
};
E:E '+' E {$$=$1+$3;}
 |E '-' E {$$=$1-$3;}
 |E '*' E {$$=$1*$3;}
 |E '/' E {$$=$1/$3;}
 |E '%' E {$$=$1%$3;}
 |'(' E ')' {$$=$2;}
 | NUMBER {$$=$1;}
 |UMINUS E {$$=-$1;}
 ;

%%

void yyerror(const char * msg) {
	printf("error:%s\n", msg);
}

int yywrap() {
	return 1;
}

int main(void)
{
	yyparse();
}
  1. 编写demo.l文件,用于完成词法分析。
%{
/* Definition section */
#include <stdlib.h>
#include "y.tab.h"
void yyerror(char *);
extern int yylval;
%}

/* Rule Section */
%%
[0-9]+ {
	yylval=atoi(yytext);
	return NUMBER;
}
[\t] ;
[\n] return 0;

. return yytext[0];
%%
  1. 利用flex和yacc命令行分别生成需要的c文件,然后利用gcc将它们编译生成可执行的计算器程序:
  2. yacc -d demo.y
    flex demo.l
    gcc y.tab.c lex.yy.c -o demo

源程序以及可执行程序:

已包含源程序和可执行程序(需要在Linux环境下执行)
https://wwpv.lanzoue.com/i46a110m1ixg

(这里仅仅包含源码和可执行文件,报告需要自己写,然后统一打包发送给老师)

flex和yacc的资料:

http://icq2002c.free.fr/book/automates/compilation/lex&yacc.pdf
https://www.ibm.com/docs/en/zos/2.3.0?topic=tools-tutorial-using-lex-yacc#lytut

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qing影

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值