编译原理利用Flex+Bison实现简单计算器

本文介绍了如何利用编译原理中的Flex和Bison工具,实现一个具备加、减、乘、除、幂运算功能的简单计算器。实验内容包括安装Linux上的Flex和Bison,编写对应的lexer和parser源文件,并详细阐述了实现过程。
摘要由CSDN通过智能技术生成

编译原理利用Flex+Bison实现简单计算器

一 实验目的

1、掌握Yacc的基本用法,并能够根据语言给出语法规则的定义,最后生成语言的解析器;

2、使用使用Yacc实现一个高级计算器程序;

二 实验内容

实现一个简单的表达式计算器,要求能进行加、减、乘、除、幂运算,注意优先级。写出详细的步骤和源程序。

1、在linux中安装flex和bison,使用如下命令:

        sudo apt-get install flex 

        sudo apt-get install bison 

   2、编写calculator.lex源程序

%{
    // 一个简单计算器的Lex词法文件
    #include <stdlib.h>
    #include "calculator.tab.h"
    void yyerror(char const *);
%}

%%
    /* a-z为变量 */
[a-z]  {
       yylval = *yytext - 'a';
       return VARIABLE;
    }

    /* 整数 */
[0-9]+ {
        
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值