关于Basic程序解释器及编译原理的简单化(1)--词法分析和代数式求值

   在网上,看到还是有部分程序爱好者希望能编出自己的编译器.当然,这的确是件难事,许多人都说要去看什么编译原理和精通汇编语言,结果让这些爱好者都望而却步.但是,当我们亲手去做做后,发现要做一个简单的程序解释器(就像Java和Basic)那样,还是挺容易的.你根本不用去看那些东西,只要你懂C语言,在看了本文后,就可以完成那样的解释器.

   在网上,有许多大型C语言,Perl语言的编译器源代码.但当你下载后看看,竟发现点都看不懂.其实那些东西还是不看为妙.看了本文后,我相信你宁愿自己动手编,也不愿意去领会那些庞大的源代码了.

   少说费话了,我们开始讲解.

这一篇Basic解释器的代码.十分经典.而且十分简单化.

get_token()是词汇提取,譬如 PRINT A+B
通过调用一次get_token(),就在 字符串token里装上PRINT
再调用一次get_token(),token里就装上A
再调用一次get_token(),token里就装上+
再调用一次get_token(),token里就装上B
很简单吧!
putback()是将prog指针向回移动一格.

   
其中包含了词发分析和十分关键的代数式求值get_exp(int *result)
关于它的代数式求值get_exp(int *result),用到递归函数
void get_exp(),level2(),level3(),level4(),level5();
void level6(),primitive(),arith(),unary();
,确实难看懂,不过你尽管拿来用就是了.

话不多说,你看源代码就是了.最后,我将给你看看C++中完整的源代码

/*
   recursive descent parser for integer expression
   which may include variables
*/

#include <stdio.h>
#include <setjmp.h>
#include <math.h>
#include <ctype.h>
#include <stdlib.h>

#define DELIMITER 1
#define VARIABLE 2
#define NUMBER 3
#define COMMAND 4
#define STRING 5
#define QUOTE 6

#define EOL 9
#define FINISHED 10

extern char *prog;  /* holds expression to be analyzed */

extern jmp_buf e_buf;  /* hold enviroment */
extern int variables[26];  /* variables */
extern struct commands {
    char command[20];
    char tok;
} table[];

extern char token[80];  /* holds string representation of token */
extern char token_type;  /* contains type of token */
extern char tok;  /* holds the internal representation of token */

void get_exp(),level2(),level3(),level4(),level5();
void level6(),primitive(),arith(),unary();
void serror(),putback();


/* entry point into parser */
void get_exp(int *result)
{
    get_token()

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: 合肥工业大学编译原理实验1是一个词法分析程序实验,使用Python语言进行编写。 词法分析编译原理中的一个重要内容,主要负责将源代码文件中的字符序列分割成有意义的词法单元,如标识符、关键字、运算符、分隔符等,为后续的语法分析和语义分析做好准备。 Python语言由于其简洁易学和强大的功能,成为许多编译原理实验的首选语言之一。在这个实验中,我们将使用Python编写一个词法分析程序,实现对源代码的分析。 首先,我们需要读取源代码文件,将其转换为字符流,传递给词法分析程序程序会逐个读取字符,并根据事先定义好的正则表达式进行匹配,识别出相应的词法单元。 实验中可能会用到的一些正则表达式包括:匹配标识符的正则表达式、匹配关键字的正则表达式、匹配运算符的正则表达式、匹配数常量的正则表达式等。 在识别出词法单元后,程序会生成一个词法单元表,记录下每个词法单元的类型和对应的。该词法单元表将作为语法分析的输入。 在编写这个词法分析程序时,需要注意处理多种可能的错误情况,如不合法的字符、不符合规范的标识符等。可以通过添加捕获异常的机制来处理这些错误情况,并及时进行提示。 综上所述,通过本次实验,我们可以学习到编译原理词法分析的基本概念和原理,并通过实践来深入理解。通过使用Python语言编写词法分析程序,我们能够更好地掌握Python语言的特性和应用。 ### 回答2: 编译原理实验一是词法分析程序实验,要使用Python语言编写程序。本实验的主要目的是通过实现词法分析,能够将输入的源代码分解成一个个的词法单元。在合肥工业大学编译原理实验一的词法分析程序实验中,我们需要实现以下功能: 1. 识别并分类各种类型的词法单元,比如标识符、数字、关键字、运算符、界符等。 2. 跳过空格、换行符和注释等不影响程序执行的字符。 3. 输出每个词法单元的类型和,方便后续程序分析和处理。 为了完成这个实验,我们可以使用Python语言提供的字符串处理函数和正则表达式库来帮助我们实现上述功能。下面是一个简单的实现示例: ```python import re def lexer(code): # 定义正则表达式,用于识别各种类型的词法单元 keywords = ['if', 'else', 'while', 'for', 'int', 'float', 'char'] # 关键字 operators = ['+', '-', '*', '/', '=', '==', '!=', '<', '>', '<=', '>='] # 运算符 delimiters = [';', '(', ')', '{', '}'] # 界符 pattern_keywords = '|'.join(keywords) pattern_operators = '|'.join(re.escape(op) for op in operators) pattern_delimiters = '|'.join(re.escape(dl) for dl in delimiters) pattern = f'({pattern_keywords})|({pattern_operators})|({pattern_delimiters})|\w+|\d+' # 开始词法分析 tokens = re.findall(pattern, code) for token in tokens: if token[0]: print(f'关键字:{token[0]}') elif token[1]: print(f'运算符:{token[1]}') elif token[2]: print(f'界符:{token[2]}') elif token[3]: print(f'标识符:{token[3]}') elif token[4]: print(f'数字:{token[4]}') # 测试代码 code = ''' int main() { int a = 10; if (a > 0) { a = a - 1; } return 0; } ''' lexer(code) ``` 以上是一个简单的词法分析程序实验的实现示例,通过使用正则表达式来识别各种词法单元,并打印出每个词法单元的类型和。实验中可以根据具体需扩展代码,添加更多的词法单元类型和识别规则。 ### 回答3: 合肥工业大学编译原理实验1是关于词法分析程序的实验。词法分析编译过程中的第一个步骤,主要任务是将源代码分解为一个个的词法单元。在这个实验中,使用Python编写词法分析程序。 在开始编写程序之前,首先需要明确程序的功能和输入输出要。根据实验要,我们需要编写一个可以识别并输出源代码中的各个词法单元的程序。 编写词法分析程序的基本思路如下: 1. 读取源代码文件,将其按照字符进行分解; 2. 针对每一个字符,判断其所属的词法单元类型; 3. 将每个词法单元及其类型输出。 在Python中,可以利用正则表达式来匹配词法单元的模式。通过定义适当的正则表达式,可以方便地判断当前字符所属的词法单元类型。可以考虑使用re模块来处理正则表达式。 实验的输入是一个源代码文件,首先需要使用Python的文件操作来读取源文件的内容。之后,可以利用re模块的正则表达式相关函数,对每个字符进行匹配和识别。最后,将每个词法单元及其类型输出到一个文件中。 编写完程序后,可以使用一些示例的源代码文件进行测试,验证程序的正确性。如果发现有问题,可以通过调试和修改代码来改进程序的逻辑和功能。 总之,合肥工业大学编译原理实验1词法分析程序实验使用Python编写,通过正则表达式对源代码进行分析和识别,并将每个词法单元及其类型输出到一个文件中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HashCodeWithJava

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值