




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
递归下降(xiàjiàng)法第一页,共23页。递归下降(xiàjiàng)分析法基本(jīběn)思想对文法中的每个非终结符编写一个函数(或子程序),每个函数(或子程序)的功能(gōngnéng)是识别由该非终结符所表示的语法成分。由于描述语言的文法常常是递归定义的,因此相应的这组函数(或子程序)必然以相互递归的方式进行调用,所以将此种分析法称为递归下降分析法。第二页,共23页。递归下降(xiàjiàng)分析法构造(gòuzào)递归下降分析程序的方法:为每个非终结符编制一个递归下降分析函数(hánshù),每个函数(hánshù)名是相应的非终结符,函数(hánshù)体则是根据规则右部符号串的结构和顺序编写。A→α1α2…αnαi∈VTαi∈VNα1α2…αn=ε第三页,共23页。递归下降(xiàjiàng)分析法(1)当遇到(yùdào)终结符a时,则编写语句if(当前(dāngqián)读来的输入符号==a)读下一个输入符号;(2)当遇到非终结符A时,则编写语句调用A();第四页,共23页。(4)当某个非终结符的规则(guīzé)有多个候选式时,按LL(1)文法的条件能唯一地选择一个候选式进行推导。(3)当遇到(yùdào)规则A→ε时,则编写语句递归下降(xiàjiàng)分析法if(当前读来的输入符号FOLLOW(A))
error();第五页,共23页。F();T'→*FT'|εGetSym();E'→+TE'|εE→E+T|TE→E+T|T(1)函数GetSym()printf(“success”);elseif(sym==‘(’)if(sym==‘)’)GetSym();error();GetSym();if(sym==‘+’)递归下降(xiàjiàng)分析法F→(E)|idelseprintf(“fail”);E→E+T|TT→T*F|FF→(E)|id例设有文法(wénfǎ)G[E]:试构造一个识别该文法(wénfǎ)句子的递归下降分析程序。递归下降(xiàjiàng)分析法第六页,共23页。 分析首先(shǒuxiān)消去文法左递归,得到文法G'[E]E→TE'E'→+TE'|εT→FT'T'→*FT'|εF→(E)|idE→E+T|TT→T*F|FF→(E)|id递归下降(xiàjiàng)分析法第七页,共23页。经过(jīngguò)验证,文法G'[E]是LL(1)文法。递归下降(xiàjiàng)分析法第八页,共23页。分析程序中定义(dìngyì)两个函数:(1)函数GetSym()功能:读进源程序的下一个单词符号并将它放在全程(quánchéng)变量sym。(2)函数error()功能(gōngnéng):出错处理程序。递归下降分析法第九页,共23页。对文法(wénfǎ)G'[E]可写出相应的递归下降分析程序如下:E→TE'E'→+TE'|εT→FT'T'→*FT'|εF→(E)|idmain(){GetSym();E();if(sym==‘#’)printf(“success”);elseprintf(“fail”);}递归下降(xiàjiàng)分析法第十页,共23页。E(){T();E'();}E'(){if(sym==‘+’){GetSym();T();E();}elseif((sym!=‘)’)&&(sym!=‘#’))error();}递归下降(xiàjiàng)分析法E→TE'E'→+TE'|ε
T→FT'T'→*FT'|εF→(E)|id第十一页,共23页。T(){F();T();}
E→TE'E'→+TE'|ε
T→FT'T'→*FT'|εF→(E)|idT(){if(sym==‘*’){GetSym();F();T();}elseif(symfollow(T'))error();}递归下降(xiàjiàng)分析法练习(liànxí):编写T’()?第十二页,共23页。F(){if(sym==‘id’)GetSym();elseif(sym==‘(’){ GetSym();E();if(sym==‘)’)GetSym();elseerror();}elseerror();}E→TE'E'→+TE'|ε
T→FT'T'→*FT'|εF→(E)|id递归下降(xiàjiàng)分析法第十三页,共23页。递归下降(xiàjiàng)分析法main(){GetSym();E();if(sym==‘#’)printf(“success”);elseprintf(“fail”);}id+id#E(){T();E'();}T(){F();T();}
见F见E'见T'返回(fǎnhuí)下一页第十四页,共23页。F(){if(sym==‘id’)GetSym();elseif(sym==‘(’){ GetSym();E();if(sym==‘)’)GetSym();elseerror();}elseerror();}递归下降(xiàjiàng)分析法返回(fǎnhuí)T第十五页,共23页。递归下降(xiàjiàng)分析法T(){if(sym==‘*’){GetSym();F();T();}elseif(symfollow(T'))error();}follow(T')={+,),#}返回(fǎnhuí)T第十六页,共23页。递归下降(xiàjiàng)分析法E'(){if(sym==‘+’){GetSym();T();E();}elseif((sym!=‘)’)&&(sym!=‘#’))error();}返回(fǎnhuí)E见T返回(fǎnhuí)E第十七页,共23页。递归下降(xiàjiàng)分析法递归下降(xiàjiàng)分析法elseprintf(“fail”);F();if(sym==‘)’)GetSym();递归下降(xiàjiàng)分析法递归下降(xiàjiàng)法elseprintf(“fail”);递归下降(xiàjiàng)分析法经过(jīngguò)验证,文法G'[E]是LL(1)文法。if(sym==‘+’)对这个例子,若采用(cǎiyòng)扩充的BNF表示法改写文法,得到G"[E]:E→T{+T}T→F{*F}F→(E)|id递归下降(xiàjiàng)分析法E→E+T|TT→T*F|FF→(E)|id第十八页,共23页。该文法是LL(1)文法,其递归下降分析程序中主函数和函数F()同上,对函数E()和函数T()用while语句描述(miáoshù)如下:递归下降(xiàjiàng)分析法第十九页,共23页。E(){T();while(sym==‘+’){GetSym();T();}}T(){F();while(sym==‘*’){GetSym();F();}}E→T{+T}T→F{*F}F→(E)|id递归下
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025-2030中国铌酸锂行业市场发展趋势与前景展望战略研究报告
- 2025-2030中国钢筋剪板机行业市场发展趋势与前景展望战略研究报告
- 2025-2030中国轿车和掀背车AVN行业市场发展趋势与前景展望战略研究报告
- 2025-2030中国轮胎行业市场深度调研及前景趋势与投资研究报告
- 2025-2030中国足浴器行业市场深度调研及发展趋势和前景预测研究报告
- 2025-2030中国超声心动图(ECG)设备行业市场发展趋势与前景展望战略研究报告
- 2025-2030中国血液稀释剂行业市场发展趋势与前景展望战略研究报告
- 2025-2030中国蛋糕模具行业市场发展趋势与前景展望战略研究报告
- 个人近期月底工作总结
- 2025-2030中国药用级藻蓝蛋白行业市场发展趋势与前景展望战略研究报告
- 人民医院呼吸科临床技术操作规范2023版
- 烟风道管道井防水构造做法及节点详图
- 埃森哲-基本财务比例与财务诊断内部报表
- 5.Braden评估表及其评分指引
- 车位租赁合同证明书
- CNCKAD自动套材使用说明书,数控冲床排版软件教程
- 2023年重庆市渝北区石船镇战旗村社区工作人员考试模拟题及答案
- GB/T 3091-2015低压流体输送用焊接钢管
- 广东省国家公务员录用体检表
- GB/T 17747.2-1999天然气压缩因子的计算第2部分:用摩尔组成进行计算
- 暖通空调(组合式空调)维护保养(检查)记录表
评论
0/150
提交评论