大多数flex程序有二义性,相同的输入可能被多种模式匹配

flex通过下面2个规则来解决

  • 匹配尽可能长的字符
  • 如果2个模式都可以匹配, 匹配更早出现的那个模式

例子

"+" { return ADD; }
"=" { return ASSIGN; }
"+=" { return ASSIGNADD; }
"if" { return KEYWORDIF; }
"else" { return KEYWORDELSE; }
[a-zA-Z_][a-zA-Z0-9_]* { return IDENTIFIER; }

以上模式中,因为 "+="更长,所以优先匹配

后三个关键字来说, 先匹配关键字

 

相关文章:

  • 2021-10-12
  • 2021-05-02
  • 2021-06-29
  • 2021-06-24
  • 2021-04-30
  • 2021-06-02
  • 2021-03-31
猜你喜欢
  • 2021-07-10
  • 2021-05-14
  • 2021-08-27
  • 2022-12-23
  • 2021-06-17
  • 2022-12-23
  • 2021-09-08
相关资源
相似解决方案