`
konsise
  • 浏览: 10803 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
最近访客 更多访客>>
社区版块
存档分类
最新评论

Lex&Yacc(3) 第一个yacc的例子

阅读更多
写一个什么都不解析的例子:
//第一部分:定义段
%%
//第二部分:规则段
mystatment:
   ;
%%
//第三部分:用户子例程段

Yacc的三部分与Lex的三部分类似。
在第一部分的定义段,包括%{和%}括起来的的C代码段、包括#include部分和变量定义;同时可能会有:%union,%start,%token,%type,%left,
%right和%nonassoc声明。
在第二部分的规则段,由Yacc语法规则和“{}”括起来的C代码组成。
在第三部分的用户子例程段,Yacc将这部分内容完全拷贝到翻译后的C文件中。也就是说你可以在这里定义自己的C函数然后在规则段中的C代码中调用它。
Yacc代码写好后,用下面的命令来翻译并编译
yacc -oyc01.c yc01.y
gcc -o yc01 yc01.c -ly
却发现不能不能运行通过,这是因为解析所要用到的yylex函数,是在lex中定义的。
所以,yacc要正确运行,需要同lex结合起来。
在这里需要说明的是:
lex处理的是词法解析,也就是说它擅长的是解析满足某一正则表达式的词法;
而Yacc处理的是语法解析,它解析各种词法按照一定的语法规则组合而成的语句。
同时,Yacc中的变量和堆栈能帮助我们顺利地提取满足词法和语法的内容。
接下来的我们看看如何使得lex和yacc进行结合,并传递解析内容。
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics