利用Lex&Yacc进行词法分析和语法分析
写在前面
利用Lex进行词法分析的流程在前面已经讲过,接下来是利用Lex&Yacc进行语法分析,最后可视化生成语法树。具体的操作视频:https://www.bilibili.com/video/BV1wY411q7aH/
语法分析流程
- 安装Lex和Yacc,见前一篇文章。
- 安装Graphviz,这篇博客不错:Python安装Graphviz 详细图文教程 哈怂Hasong。
- 利用flex生成lex.yy.c文件。flex lex.l
- 利用bison生成yacc.tab.c和yacc.tab.h。bison -d yacc.y
- 利用gcc来编译这两个c文件,默认生成a.exe。
- 在in.txt中输入想要的程序,并运行a.exe。
- 之后在没有语法错误的情况下运行tree.py。
注意
- 文法比较老,但很全,需要大家自己探索自己写的C程序是否有问题。
- 可视化的时候一定要看环境是否安装好。
Lex免费测试:https://github.com/zhanzhanblue/lex-using
源码:https://mbd.pub/o/bread/Y56bk5Zt