编译原理实验一:简单PL/0词法分析器C语言代码

本文介绍了一种简单的PL/0词法分析器的C语言实现方法。通过定义关键字、标识符、常量、运算符和界符的数组,对输入的字符串进行匹配,识别并标记词法单元。实验中遇到的关键点包括处理空格、识别用户自定义标识符以及注意特定符号的拼写。虽然实验指导书中提及了更复杂的枚举类型,但作者认为对于实验一来说并不必要,代码已经能够满足基本需求。

思路分析:我的个人思路比较简单,首先定义几个二维数组,分别保存PL语言关键字,界符,或者运算符,然后在主函数中,读入字符串,或者从文件中读入,然后对字符串进行分割,进行一些过滤空格(ASCII码为10,换行的ASCII码为13),之后将分割后的字符串与我们定义的数组进行比较(这相当于一个词库),假如匹配,就与之对应对它进行标记,如果既不是关键字,也不是界符.运算符,那么就是用户自定义的标识符.然后分别输出就OK.


code类别表:

1 : 关键字
2 : 标识符
3 : 常量
4 : 运算符
5 : 对应的是界符中元素的位置


关键字只有如下几个:

Const——用来声明常量;

评论 3
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值