自己动手写basic解释器(三)

本文介绍如何在Basic解释器中实现表达式求解功能,通过构建二叉树并运用递归算法来计算复杂的数学表达式。

自己动手写basic解释器

刺猬@http://blog.csdn.net/littlehedgehog

 





注: 文章basic解释源码摘自梁肇新先生的《编程高手箴言》(据他所说这个代码也是网上摘录的),源码解读参考《java编程艺术》。《java编程艺术》里面自然是java版了(可能旭哥更加适合点儿),我这里还是解读的C版basic解释器代码。




经过get_token,我们可以获取一个标识符,按理说来下步可以进行程序逻辑处理了,但是标识符获取后我们离后面的真正程序逻辑运行还有一个大障碍,这就是表达式求解的问题。 比如说我们遇到一条语句    PRINT  3*(a+b)这里print 倒是能识别是个关键字,我们按照程序逻辑应该打印后面的东东,是字符串就直接打印,是变量就取值打印,但是这里偏偏是一个表达式,我们需要事先计算出表达式的值。接下来的问题就演变成了如何计算一个表达式,或者说写一个四则运算器。

关于如何写四则运算器,网上相关资料很多,源代码里的函数我没有解读,主要是看着不爽,逻辑性不够。再者这个东西其实我大一自学数据结构的时候写过,主要思想是建立二叉树,然后类似一个中序遍历即可。这里稍作解释,具体代码分析就不写了。大家可以参照我原来的博客《四则运算》《重言式判别》。

我们策略是设置运算符权值,具体规则是设置初始权值为0,扫描整个表达式,遇到+ - 号权值加1,赋给当前运算符号,遇到乘除号,权值加2,赋值;遇到乘方号,权值加3,赋值;遇到左括号,权值加4,遇到右括号,权值减4。 比如
3+3*(4-2)  初始权值赋值为0  第一个加号,加上1,赋给加号。第二个乘号权值加上2,权值为2(注意前面权值加一只是为了赋值,本身不变),赋给乘号。后面遇到左括号,权值本身再加4,这时权值为4,但是这里不赋值,因为括号不参与运算,当然这只是我这里图方便,你说要赋值也不是不可,就是后面麻烦点儿。马上又是减号,权值加1赋值,减号的权值变5,接着是右括号,权值减4。所以整个下来有
3+3*(4-2)    表达式
   1   2  5       权值

权值分析完毕,然后就是找出最小权值的一个符号,作为二叉树的根,权值越大的越往下生长,叶子节点全是数字。然后递归遍历解决。我原来那个程序只能计算表达式,但其实稍作改动就能计算变量了。在此不再赘述。下面贴出计算核心代码:
  1. double calculator(binarytree *root)
  2. {
  3.     if(root)
  4.     {
  5.         if(root->left==NULL&&root->right==NULL)
  6.             return atof(&root->data);
  7.         else 
  8.         {
  9.             switch(root->data)
  10.            {
  11.             case '*':
  12.                 return calculator(root->left)*calculator(root->right);
  13.                 break;
  14.             case '/':
  15.                 return calculator(root->left)/calculator(root->right);
  16.                 break;
  17.             case '+':
  18.                 return calculator(root->left)+calculator(root->right);
  19.                 break;
  20.             case '-':
  21.                 return calculator(root->left)-calculator(root->right);
  22.                 break;
  23.             case '^':
  24.                 return pow(calculator(root->left),calculator(root->right));
  25.             default:
  26.                 break;
  27.             }
  28.         }
  29.     }
  30. }

经过表达式求解函数get_exp(value)处理后,我们就得到这个表达式的值了。这样,万事具备,就等着程序的逻辑处理...



### 回答1: 自己动手一个Basic解释器(也就是将Basic语言的代码转化为计算机可以理解的指令集合)需要一定的编程知识和技能。以下是一个简要的步骤介绍,以帮助您编一个基本的Basic解释器。 第一步是理解Basic语言的语法和特性。Basic是一种面向过程的编程语言,其语法包括变量的声明、赋值和操作,循环结构,条件语句,函数和子程序等。 第二步是设计解释器的整体架构。你需要决定如何表示和存储变量、函数和代码的执行顺序。这可以通过数据结构(如符号表、堆栈和解析树)来实现。 第步是编一个词法解析器,将Basic代码分解为一个个的词法单元(如关键字、操作符和标识符)。词法解析器可以使用正则表达式或手动编的代码实现。 第四步是编一个语法解析器,将词法单元转化为可执行的指令。这可以通过使用解析器生成器(如Yacc/Bison)或手动编的代码来实现。 第五步是实现变量和表达式的存储和计算。你需要设计适当的数据结构来存储变量的值,并在执行代码时对表达式进行求值。 第六步是实现控制结构,如循环和条件语句。你需要考虑如何跟踪和修改代码的执行路径,以实现控制流程的正确运行。 第七步是实现函数和子程序的定义和调用。你需要设计一种数据结构来存储函数的参数和局部变量,并在调用函数时正确地传递参数和保存返回值。 第八步是测试解释器的功能和性能。编一些基本的Basic代码,并验证解释器能够正确地解释并执行这些代码。 总结而言,自己动手一个Basic解释器需要深入理解Basic语言的语法和特性,并具备编程基础知识和技能。通过合理设计解释器的架构,编词法解析器、语法解析器和执行引擎,最后进行测试和调试,就可以实现一个基本的Basic解释器。 ### 回答2: 编一个 BASIC 解释器是一项相对复杂的任务,需要对计算机系统和编程语言规范有一定的了解和技能。在简要介绍这个解释器的实现过程之前,可以先了解一下 BASIC 编程语言的基本特性和工作原理。 BASIC(Beginner's All-purpose Symbolic Instruction Code)是一种旨在教授编程基础的高级编程语言,具有易学易用的特点。一个 BASIC 解释器的主要任务是读取并解释 BASIC 代码,将其转化为计算机能够理解和执行的指令。 为了编一个 BASIC 解释器的 zip 版本,我们可以按以下步骤进行操作: 1. 了解 BASIC 语言规范:熟悉 BASIC 语言的基本语法和关键字,例如变量、循环、条件语句等。这样才能准确解析和执行 BASIC 代码。 2. 设计词法分析器:编一个词法分析器,用于将输入的 BASIC 代码分解成标记(Tokens),例如关键字、变量名和数值等。这个过程称为词法分析。 3. 设计语法分析器:编一个语法分析器,根据 BASIC 语法规则将标记转化为语法树。语法树是一个树形结构,用于描述程序的结构和执行顺序。 4. 设计执行引擎:在基于语法树的基础上,编一个执行引擎,按照语法树的指令顺序逐条执行 BASIC 代码。这个过程涉及到变量管理、循环控制、条件判断等。 5. 实现基本功能和特性:根据 BASIC 语言规范,逐步实现基本的功能和特性,例如变量赋值、循环结构、条件判断、输入输出等。确保解释器能够正确解析和执行这些功能。 6. 进行测试和调试:编一些简单的 BASIC 代码进行测试,并且调试解释器中出现的错误和问题。持续进行测试和修复,直到解释器能够正确处理各种情况下的 BASIC 代码。 总结起来,编一个 BASIC 解释器需要一定的计算机科学基础和编程技能。通过设计词法分析器、语法分析器和执行引擎等模块,实现解释器的基本功能和特性。最后,通过测试和调试确保解释器能够正确解析和执行 BASIC 代码。 ### 回答3: 编 BASIC 解释器是一个非常有趣和有挑战性的任务。BASIC(Beginner's All-purpose Symbolic Instruction Code)是一种广泛使用的高级程序设计语言,在学习编程的初级阶段非常流行。基本的解释器应该能够解析和执行 BASIC 代码。 首先,需要设计和实现一个词法分析器(lexer),它能够将 BASIC 代码分解成一个个的词法单元,例如关键字、标识符、运算符和常量。然后,需要编一个语法分析器(parser),使用上一步的词法单元构建抽象语法树(AST),以表示 BASIC 代码的结构和语义。 接下来,解释器需要按照 BASIC 语法规则,逐行解析和执行 AST。这包括执行赋值语句、条件语句、循环语句等。对于变量的维护,需要实现一个符号表(symbol table),用于存储和管理变量的值和类型。 在执行过程中,解释器还需要实现算术和逻辑运算、函数调用和参数传递等功能。同时,解释器还需要处理用户输入和输出,以便与用户交互。 最后,为了提高解释器的性能和效率,可以添加优化和解释器技巧,例如解释器解释器、即时编译等。 总之,编 BASIC 解释器需要深入理解 BASIC 语言的语法和语义,熟悉编译原理和解释器设计。通过实现一个自己的 BASIC 解释器,可以更好地理解程序执行的原理和底层工作机制。这对于提高编程技能和理解高级语言的内部运行方式非常有帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值