Lex 生成一个词法分析器

打印 上一主题 下一主题

主题 888|帖子 888|积分 2664


 lex 通过输入一个.l 文件生成一个lex.yy.c 文件,然后通过c 编译器编译成一个可执行的词法分析器。 该词法分析器扫描输入源文件,生成一个token 符号流给后面语法分析器使用。
 
.l 文件的结构, 分成三个部分,声明, 转换规则, 自定义规则。 三个部分由%%分割
  1. declarations
  2. %%
  3. translation rules
  4. %%
  5. auxiliary procedures<br>
复制代码
声明段, 包含希望出现出现再目标c文件种的代码, 正则表达式的声明。符号常量的声明。%{ %} 包裹内容
  1. <em id="__mceDel">#include <stdio.h>  
  2. #include "y.tab.h"
  3. typedef char * YYSTYPE;  // 符号常量声明
  4. char * yylval;           <br>/* regular definitions */ <br><br>2delim [ \t\n]ws <br><br>letter [A-Za-z]<br>digit [0-9]<br>
  5. %}</em>
复制代码
规则段  由正则表达式和动作组成  {} 内表示要执行的代码动作
  1. %%
  2. /*  {BEGIN(commemts)}   
  3. */   {END(comments)}
  4. .....
  5. %%
复制代码
  自定义规则
其他内嵌代码

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

怀念夏天

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表