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

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

被折叠的 条评论
为什么被折叠?



