Loading...
前提只有当文法已经是LL(1)文法了,才可以为其构造分析表,否则无法构造(二义等)构造方法对于一个文法G的每个产生式 A→α进行如下处理:对于FIRST(α)中的每个终结符号a,将A→α加入到M[A,a]。如果ε在FIRST(α)中,那么:对于FOLLOW(A)中的每个终结符号b,将A→α加入到M[A,b]。若$在FOLLOW(A)中,将A→α加入到M[A,$]。例有如下LL(1)文法:E ...
组成存放当前分析进程的栈,栈底为$以$结尾的输入语句分析表,起决策作用预测分析程序,执行决策输出,语法分析数流程假设当前栈顶元素为X,输入符号为a,有三种可能性:如果X=a=$,分析器宣布分析完成成功而停机。如果X=a≠$,分析器弹出栈顶元素,并推进输入指针,使之指向限一个输入符号。如果X是非终结符号,程序访问分析表M,若M[X,a]是X的产生式,例如M[X,a]={X→UVM},那么分析器...
预测分析是指能够根据当前输入未非终结符确定采用哪一种选择递归下降的预测分析是指为每一个非终结符写一个分析过程(函数),这个过程可能会调用自己例.有下列产生式:type -> simple | ↑ id | array [ simple ] of typesimple-> integer | char | num dotdot num首先构造match函数,其作用是匹配当前的终结符...