我有一个下面列出的lex程序,它识别(词法分析)特定的令牌,并在从键盘输入时将它们输出到屏幕。我想使用yacc进行下面代码的语法分析,但我不太明白这个部分.....输出会是什么样子?我的代码是否足够?我在网上看过很多关于yacc的文章....只需要有人给出一个简单的解释。提前谢谢......
/* Regular Definitions */
RelationalOp_1 "<"
RelationalOp_2 "<="
RelationalOp_3 "=<"
RelationalOp_4 "=="
RelationalOp_5 "!="
RelationalOp_6 ">"
RelationalOp_7 ">="
RelationalOp_8 "=>"
%%
{RelationalOp_1} {printf("(RelationalOp_1, %s)\n", yytext);}
{RelationalOp_2} {printf("(RelationalOp_2, %s)\n", yytext);}
{RelationalOp_3} {printf("(RelationalOp_3, %s)\n", yytext);}
{RelationalOp_4} {printf("(RelationalOp_4, %s)\n", yytext);}
{RelationalOp_5} {printf("(RelationalOp_5, %s)\n", yytext);}
{RelationalOp_6} {printf("(RelationalOp_6, %s)\n", yytext);}
{RelationalOp_7} {printf("(RelationalOp_7, %s)\n", yytext);}
{RelationalOp_8} {printf("(RelationalOp_8, %s)\n", yytext);}
. printf("Invalid input: %s\n",yytext);
%%
main()
{
yylex();
}
yywrap()
{
}
答案 0 :(得分:0)
对您的问题的简短回答是否定的,使用yacc生成的解析器,您所拥有的内容是不完整的。在lex生成的扫描程序中,您希望在内存中为解析器提供令牌,而不是简单地将某些内容写入控制台。
为了理解上下文,Pete Jinks's lecture notes是全面的,并展示了lex和yacc生成的程序如何协同工作。您还可以查看Bison的在线手册,它是yacc的GNU版本。