flex 编写一个回显整数小数单词的词法分析器,为什么输入 1. 会回显 1 呢,不应该不回显吗
%{
#include <stdio.h>
#include <string.h>
%}
digit ([1-9]+[0-9]*)|[0]
dotdigit ([0]|[1-9]+)\.[0-9]+
word [a-zA-Z]+
%%
{digit} ECHO;
{dotdigit} ECHO;
{word} ECHO;
.
%%
int main(int argc, char** argv)
{
yylex();
return 0;
}
1 .
1
aaaa.
aaaa
aaa .111
aaa111
aa&cc&.
aacc
测试了这么几个用了,可以得出一个简单结论:对于内容的匹配是对全文中感兴趣的token进行处理。对于不识别的字符不会导致整体匹配失败。
1.输入中,1匹配了digit规则,进行了ECHO,.被忽略
1.被当作整数1,而非小数1.,如果要当作小数,可以把dotdigit的最后一部分的+改为*