深入探索Flex与Bison:从基础到应用
1. Flex基础与简单应用
Flex 是一个强大的工具,用于生成词法分析器。在使用 Flex 时,我们可以定义各种模式(patterns)来匹配输入的字符序列,并为每个模式指定相应的动作(actions)。
例如,在统计字符数的程序中,最后一个模式是一个点号( . ),在正则表达式中,点号代表任意字符(类似于 shell 脚本中的 ? )。其动作是更新字符数。以下是运行该程序的步骤:
1. 使用 flex 命令将我们的程序转换为 C 代码:
$ flex fb1-1.l
- 编译生成的 C 代码
lex.yy.c,并链接 Flex 库:
$ cc lex.yy.c -lfl
- 运行生成的可执行文件,并输入一些文本进行测试:
$ ./a.out
The boy stood on the burning deck
shelling peanuts by the peck
^D
2 12 63
$
实际的 wc 程序对单词的定义略有不同,它将非空白字符的字符串视为一个单词
超级会员免费看
订阅专栏 解锁全文
4

被折叠的 条评论
为什么被折叠?



