深入理解Flex与Bison:从程序实现到语法解析
1. 大型Flex程序示例
在实际开发中,有时需要处理特定于当前程序的同一目录下的文件,同时跳过其他目录中的库文件。以下是一个大型Flex程序的主程序示例:
int main(argc, argv) int argc; char **argv; { int i; if(argc < 2) { fprintf(stderr, "need filename\n"); return 1; } for(i = 1; i < argc; i++) { if(newfile(argv[i])) yylex(); } printrefs(); return 0; }这个程序的主要逻辑是:如果命令行参数少于2个,会输出错误信息并返回;否则,会遍历每个文件名,调用newfile函数,如果成功则调用yylex函数,最后调用printrefs函数。该程序有较为复杂的模式集合和文件I/O操作,并对读取的文本进行了相应处理。
下面是一些相关的练习题:
1.字符匹配问题:示例2 - 3是逐个字符进行匹配,为何不使用如^.*\n这样的模式按行匹配?请考虑^.*无法工作的原因,并提出能匹配更大文本块的模式或模式组合。
2.大小写处理问题