ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

编译原理——算符优先分析法详解

2022-05-20 00:34:35  阅读:170  来源: 互联网

标签:算符 文法 终结符 短语 LASTVT 编译 详解 FIRSTVT


概述

       算符优先分析法(Operator Precedence Parse)是仿效四则运算的计算过程而构造的一种语法分析方法。算符优先分析法的关键是比较两个相继出现的终结符的优先级而决定应采取的动作。

       优点:简单,有效,适合表达式的分析。

       缺点:只适合于算符优先文法,是一个不大的文法类。
名词解释

定义:

    短语:设有文法G,S是开始符号,设abd是G的一个句型,若有SÞabd且AÞb则称b是句型abd关于A的短语。

    直接短语:在上面定义中,如果A直接推出b,即AÞb,则称b是句型abd关于A®b的直接短语。

    句柄:一个句型的最左直接短语称为句柄。

    素短语:文法G某句型的一个短语是素短语,当且仅当它至少含有一个终结符,且除它自身之外不再含更小的素短语。

    最左素短语:在具有多个素短语的句型中处于最左边的那个素短语。

求法:

    短语:从根结点出发一层一层地找出所有非叶子结点的非终结符,每一个非终结符延伸下去的所有叶子结点从左到右排列起来就是一个短语。

    直接短语:找出所有仅有两代的子树,并将它的所有叶子从左到右排列起来就是一个直接短语。

    句柄:从直接短语集合中找出最左边的短语。

    素短语:从短语集合中找出所有含有终结符的短语,然后选出除它自身之外不再含更小的素短语(这个小的概念是集合中没有被包含的元素,如有两个短语aAA和aAAA,aAA含于aAAA,所以aAA比aAAA小)

    最左素短语:从素短语集合中找出最左边的素短语。
FIRSTVT集和LASTVT集

FIRSTVT集

定义:FIRSTVT(P)={a|P=>a…,或P=>Qa…,a属于VT,Q 属于VN}

求法:

    若P→a…或P→Qa…, 则a属于FIRSTVT(P);

    若P→Q…, 则FIRSTVT(Q)含于FIRSTVT(P);

    直至FIRSTVT(P)不再增大。

LASTVT集

定义:LASTVT(P)={a|P=>...a,或P=>…aQ,a含于VT,Q 含于VN}

求法:

    若P→...a或P→…aQ, 则a属于LASTVT(P);

    若P→...Q, 则LASTVT(Q)含于LASTVT(P);

    直至LASTVT(P)不再增大。

 
构造算符优先关系表

以以下文法为例:

        E→E+T|T

        T→T*F|F

        F→(E)|i

 

终结符之间的优先关系

对算符文法G,  a,b属于VT 定义

(1)a=b:  G中有P→. . .ab. . .或P→. . .aQb. . .

(2)a<b:  G中有P→. . .aQ. . .且Q=>b…或Q=>Rb...

(3)a>b:  G中有P→. . .Qb. . . 且Q=>. ..a或Q=>…aR

 

算符优先关系表的构造

(1)  在文法中添加E→#E#。

(2)  求出FIRSTVT和LASTVT集

(3)  找出所有终结符,并画出关系表的结构

(4)  从文法中找出形为aQb(终结符+非终结符+终结符)和ab(终结符+终结符)的部分,本例中为(E)和#E#,然后在(和)与#和#相应的表格填=。

(5)  从文法中找出形为aQ(终结符+非终结符)的部分,a与Q的FIRSTVT集合中每一个元素在表格中的交叉点填小于号。

    i.找出形为aQ的部分

    

    ii.填小于号(终结符为竖排,非终结符中的元素为横排,以横排为基准填符号)

    

(6)  从文法中找出形为Qa(非终结符+终结符)的部分, Q的LASTVT集合中每一个元素与a在表格中的交叉点填大于号。
    i.找出形如Qa的部分
    

    ii.填大于号(非终结符中的元素为横排,终结符中的元素为竖排,以竖排为基准填符号)

    

(7)  合并后的结果为

    

 

    从上表可知:

    (1)相同终结符之间的优先关系未必是=

    (2)有a<b,未必有b>a

    (3)a、b之间未必一定有优先关系

 

    故=、<、>不同于关系运算符“等于”、“小于”、“大于”
————————————————
版权声明:本文为CSDN博主「Ayratt」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_37977106/article/details/80301761

标签:算符,文法,终结符,短语,LASTVT,编译,详解,FIRSTVT
来源: https://www.cnblogs.com/jiftle/p/16290865.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有