bison生成c语言文件指令,第13章 用 bison 做语法分析

本文通过实例展示了如何使用Bison工具创建一个简单的C语言语法分析器。介绍了如何编写词法分析器calc.l和语法分析器calc.y,包括安装Bison,创建和编辑calc.l和calc.y文件,以及编译和运行生成的C代码,实现了一个支持加减乘除和括号的整数计算器。最后解释了calc.l和calc.y文件的代码结构和工作原理。
摘要由CSDN通过智能技术生成

13.2 bison 示例 1¶

上面这段话可能不太容易理解,还是来看一个简单的例子吧。首先安装 bison ,在终端输入:

sudo apt-get install bison

安装完成后,新建一个文本文件,输入以下内容:

%{

#include "y.tab.h"

%}

%%

[0-9]+ { yylval = atoi(yytext); return T_NUM; }

[-/+*()\n] { return yytext[0]; }

. { return 0; /* end when meet everything else */ }

%%

int yywrap(void) {

return 1;

}

将此文件另存为 calc.l 。注意此文件中的 %% 、 %{ 、 %} 的前面不能有任何空格。

再新建一个文本文件,输入以下内容:

%{

#include

void yyerror(const char* msg) {}

%}

%token T_NUM

%left '+' '-'

%left '*' '/'

%%

S : S E '\n' { printf("ans = %d\n", $2); }

| /* empty */ { /* empty */ }

;

E : E '+' E { $$ = $1 + $3; }

| E '-' E { $$ = $1 - $3; }

| E '*' E { $$ = $1 * $3; }

| E '/' E { $$ = $1 / $3; }

| T_NUM { $$ = $1; }

| '(' E ')' { $$ = $2; }

;

%%

int main() {

return yyparse();

}

将此文件另存为 calc.y 。注意此文件中的 %% 、 %{ 、 %} 的前面也不能有任何空格。

将前面两个文件都放在终端的当前目录,再在终端输入:

bison -vdty calc.y

此时可以发现终端下多了三个文件: y.tab.h, y.tab.c, y.output 。

再在终端输入:

flex calc.l

此时终端下又多了一个文件: lex.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值