您的位置:首页 > 其它

第二章 flex处理二义性

2015-07-11 09:11 204 查看
大多数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; }


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

后三个关键字来说, 先匹配关键字
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: