flex&bison-一个简单计算器程序

文章介绍了使用Flex和Bison两个工具来生成词法分析器和语法分析器的过程。Flex用于处理lex文件,生成词法分析的C代码,而Bison处理y文件,生成语法分析的C代码。通过示例展示了如何编写flex和bison规则,并利用makefile进行编译。最终,演示了处理数学表达式的例子,显示了工具组合的效果。
摘要由CSDN通过智能技术生成

导读

flex : 用于生成词法分析的程序,可以生成lex.yy.c文件。
bison:用于生成语法分析的程序,可以生成*.tab.h 和 *.tab.c文件。

flex规则

flex文件内容主要分为三段,每一段用%%分割,calc.l如下

%{
#include "calc.tab.h"
%}

%option noyywrap

%%
"("     { return OB; }
")"     { return CB; }
"+"     { return ADD; }
"-"     { return SUB; }
"*"     { return MUL; }
"/"     { return DIV; }
[0-9]+  { yylval = atoi(yytext); return NUM; }
\n      { return EOL; }
[ \t]   { }

%%

第一段: %{ %}部分会原封不动放入到yy.lex.c
第二段:是匹配模式,规则 动作,规则可以使正则表达式, 动作是C语言代码段。
第三段:可以放一些C代码。

bison规则

bison文件内容主要分为三段,每一段用%%分割,calc.y如下

%{
#include <stdio.h>
%}
%token NUM
%token ADD SUB MUL DIV
%token EOL
%token OB CB

%%

expr: factor { $$ = $1;}
    | expr ADD factor { $$ = $1 + $3; }
    | expr SUB factor { $$ = $1 - $3;}
    | expr EOL { printf("result : %d\n", $1);}
    ;

factor: term { $$ = $1; }
    | factor MUL term { $$ = $1 * $3; }
    | factor DIV term { $$ = $1 / $3; }
    ;

term: NUM { $$ = $1;}
    | OB expr CB { $$ = $2; }
    ;

%%

int
main(int argc, char *argv[])
{
        yyparse();
        return 0;
}


void 
yyerror(char * e)
{
        printf("%s\n", e);
}

第一段:%{ %}用来编写一些代码段,%token用于声明记号给词法分析程序使用。
第二段:BNF规则,其中|表示或,每条规则以符号;结束,规则表达式后面可以跟一个动作,动作是一段C语言代码段。
第三段:可以放一些c代码,这里yyparse会调用词法分析程序处理字符流并根据返回的记号执行响应的动作。

makefile文件

calc:
        bison -d calc.y
        flex calc.l
        cc -o calc calc.tab.c lex.yy.c

效果

zhangliang[zhangl@localhost ~/test/bison/calc]$ echo "1+3*(2+2)/(3-1)+13" | ./calc
result : 20
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值