flex+bison写一个简单的加法计算程序

文件总计2个

  • 一个是flex的词法文件,lexer.l,它定义了基本的规则
  • 一个是bison的解析文件parser.y

lexer.l

%{
    /* definitions*/
    #include "parser.tab.h"
%}

/* rules */
%%

[0-9]+  { yylval.num= atoi(yytext); return NUMBER;}
"+"     { return PLUS; }
\n      { return EOL; }
.       {}


%%

yywrap() {}

整个文件以%%分割成三个部分。

第一个部分为定义域,这里有include “parser.tab.h”,它包含的头文件是后面部分生成的,主要是引入在另外一个文件parser.y中的符号定义。

中间部分是规则,第一条规则是将数字转为NUMBER,这个符号也在parser.y中定义。
第二条规则是将+转为PLUS符号
第三条规则是将\n(换行符)转为EOL符号(End of Line)
第四条规则是忽视其他符号


parser.y

%{
    /* definitions*/

%}

%union {
    int num;
    char sym;
}
%token EOL
%token<num> NUMBER
%type<num> exp
%token  PLUS

/* rules */
%%

input: 
|   EOL
|   line input;

line:
    exp EOL { printf("%d\n",$1); }

exp:
    NUMBER { $$ = $1; } | exp PLUS exp { $$ = $1 + $3; } ;

%%


int main() {
    yyparse();
    return 0;
}


int yyerror(char *err) {
   printf("ERROR: %s\n", err);
   return 0;
}


解析词法

flex lexer.l

它会生成 lex.yy.c

bison -d -t parser.y

它会生成 parser.tab.hparser.tab.c

其中parser.tab.h 在lexer.l中的定义部分有包含,它主要是引入了parser.y中的定义符号,如EOL。

编译

gcc lex.yy.c parser.tab.c

生成a.out

执行a.out
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值