编译原理词法分析.ppt
《编译原理词法分析.ppt》由会员分享,可在线阅读,更多相关《编译原理词法分析.ppt(115页珍藏版)》请在三一办公上搜索。
1、第2章 词法分析,2.1 词法分析器设计方法 2.2 一个简单的词法分析器示例 2.3 正规表达式与有限自动机简介 2.4 正规表达式到有限自动机的构造 2.5 词法分析器的自动生成,2.1 词法分析器设计方法,词法分析是编译的第一个阶段,其任务是:从左至右逐个字符地对源程序进行扫描,产生一个个单词符号,把字符串形式的源程序改造成为单词符号串形式的中间程序。执行词法分析的程序称为词法分析程序,也称为词法分析器或扫描器。词法分析器的功能是输入源程序,输出单词符号。,词法分析可以采用如下两种处理结构:(1)把词法分析程序作为主程序。将词法分析工作作为独立的一遍来完成,即把词法分析与语法分析明显分开
2、,由词法分析程序将字符串形式的源程序改造成单词符号串形式的中间程序,以这个中间程序作为语法分析程序的输入。在这种处理结构中,词法分析和语法分析是分别实现的,如图21(a)所示。,(2)把词法分析程序作为语法分析程序调用的子程序。在进行语法分析时,每当语法分析程序需要一个单词时便调用词法分析程序,词法分析程序每一次调用便从字符串源程序中识别出一个单词交给语法分析程序。在这种处理结构中,词法分析和语法分析实际上是交替进行的,如图21(b)所示。由于把词法分析器安排成一个子程序比较自然,因此,词法分析程序通常采用第二种处理结构。,图2-1 词法分析的两种处理结构(a)词法分析程序作为主程序;(b)词
3、法分析程序作为子程序,2.1.1 单词符号的分类与输出形式 1单词符号分类 词法分析程序简单地说就是读单词程序,该程序扫描用高级语言编写的源程序,将源程序中由单词符号组成的字符串分解出一个个单词来。因此,单词符号是程序语言的基本语法单位,具有确定的语法意义。程序语言的单词符号通常可分为下面五种:,(1)保留字(也称基本字):如C语言中的if、else、while和do等,这些字保留了语言所规定的含义,是编译程序识别各类语法成分的依据。几乎所有程序语言都限制用户使用保留字来作为标识符。(2)标识符:用来标记常量、数组、类型、变量、过程或函数名等,通常由用户自己定义。(3)常数:包括各种类型的常数
4、,如整型常数386、实型常数0.618、布尔型常数TRUE等。,(4)运算符:如“+”、“?”、“*”、“/”、“”、“”等。(5)界符:在语言中是作为语法上的分界符号使用的,如“,”、“;”、“(”、“)”等。一个程序语言的保留字、运算符和界符的个数是确定的,而标识符或常数的使用则不限定个数。,2词法分析程序输出单词的形式 我们知道,词法分析程序的输入是源程序字符串,而输出是与源程序等价的单词符号序列,并且所输出的单词符号通常表示成如下的二元式:(单词种别,单词自身的值)(1)单词种别。单词种别表示单词的种类,它是语法分析所需要的信息。一个语言的单词符号如何划分种类、分为几类、如何编码都属于
5、技术性问题,主要取决于处理上的方便。通常让每种单词对应一个整数码,这样可最大限度地把各个单词区别开来。,对于保留字,可将其全体视为一种,也可一字一种,采用一字一种的分类方法处理起来比较方便;标识符一般统归为一种;常数可统归为一种,也可按整型、实型、布尔型等分为几种;运算符和界符可采用一符一种的分法,也可统归为一种。,(2)单词自身的值。单词自身的值是编译中其它阶段所需要的信息。对于单词符号来说,如果一个种别只含有一个单词符号,那么对于这个单词符号,其种别编码就完全代表了它自身的值。如果一个种别含有多个单词符号,那么对于它的每个单词符号,除了给出种别编码之外还应给出单词符号自身的值,以便把同一种
6、类的单词区别开来。注意,标识符自身的值就是标识符自身的字符串,而常数自身的值是常数本身的二进制数值。此外,我们也可用指向某类表格中一个特定项目的指针来区分同类中的不同单词。例如,对于标识符,可以用它在符号表的入口指针作为它自身的值;而常数也可用它在常数表的入口指针作为它自身的值。,2.1.2 状态转换图 在词法分析中,可以用状态转换图来识别单词。状态转换图是有限的有向图,结点代表状态,用圆圈表示;结点之间可由有向边连接,有向边上可标记字符。例如,图2-2表示在状态i下,若输入字符为x,则读入x并转换到状态j;若输入字符为y,则读入y并转换到状态k。状态(即结点)数是有限的,其中必有一初始状态以
7、及若干终止状态,终止状态(终态)的结点用双圈表示以区别于其它状态。图2-3给出了用于识别标识符、无符号整数、无符号数的状态转换图,其初始状态均用0状态表示。,图22 不同输入字符的状态转换,图2-3 标识符及无符号数的状态转换图(a)标识符;(b)无符号整数;(c)无符号数,当到达一类单词符号的终止状态时即可给出相应的单词编码。某些终止状态是在读入了一个其它不属于该单词的符号后才得到相应的单词编码的,这表明在识别单词的过程中多读入了一个符号,所以识别出单词后应将最后多读入的这个符号予以回退;我们对此类情况的处理是在终态上以“*”作为标识。对于不含回路的分支状态来说,可以让它对应一个switch
8、()语句或一组if-else语句。例如,图2-4(a)的状态i所对应的switch语句如下:,s=getchar();switch(s)case a:case b:case z:;/*实现状态j功能的语句*/case 0:case 1:case 9:;/*实现状态k功能的语句*/,对于含回路的状态来说,可以让它对应一个while语句。例如,图2-4(b)的状态i所对应的while语句如下:getchar();while(letter()|chgit()getchar();/*实现状态j功能的语句*/终态一般对应一个return()语句;return意味着从词法分析器返回到调用段,一般指返回到语
9、法分析器。,图2-4 含有分支或回路的状态示意(a)含分支的状态i;(b)含回路的状态i,2.2 一个简单的词法分析器示例,2.2.1 C语言子集的单词符号表示 一个非常重要的事实是:大多数程序语言的单词符号都可以用状态转换图予以识别。作为一个综合例子,我们来构造一个C语言子集的简单词法分析器。表2.1列出了这个C语言子集的所有单词符号以及它们的种别编码和内码值。由于直接使用整数编码不利于记忆,故该例中用一些特殊符号来表示种别编码。,表2.1 C语言子集的单词符号及内码值,2.2.2 C语言子集对应的状态转换图 在设计的状态转换图中,首先对输入串做预处理,即剔除多余的空白符(在实际的词法分析中
10、,预处理还包括剔除注释和制表换行符等编辑性字符的工作),使词法分析工作既简单又清晰。其次,将保留字作为一类特殊的标识符来处理,也即对保留字不专设对应的状态转换图,当转换图识别出一个标识符时就去查对表2.1的前五项,确定它是否为一个保留字。当然,也可以专设一个保留字表来进行处理。图25就是对应表2.1这个简单词法分析的状态转换图。,图25 简单词法分析的状态转换图,在状态2时,所识别出的标识符应先与表2.1的前五项逐一比较,若匹配,则该标识符是一个保留字,否则就是标识符。如果是标识符,应先查符号表,看表中是否有此标识符。若表中无此标识符,则将它登录到符号表中,然后返回其在符号表中的入口指针(地址
11、)作为该标识符的内码值;若表中有此标识符,则给出重名错误信息。在状态4时,应将识别的常数转换成二进制常数并将其登录到常数表,然后返回其在常数表中的入口指针作为该常数的内码值。,2.2.3 状态转换图的实现 状态转换图非常容易用程序实现,最简单的办法是让每个状态对应一小段程序。对于图25的状转换图,我们首先引进一组变量和过程如下:(1)character:字符变量,存放最新读入的源程序字符。(2)token:字符数组,存放构成单词符号的字符串。(3)getbe():若character中的字符为空白,则调用getchar(),直至character为非空白符为止。,(4)concatenatio
12、n():将token中的字符串与character中的字符连接并作为token中新的字符串。(5)letter()和digit():判断character中的字符是否为字母和数字的布尔函数,是则返回true,否则返回false。(6)reserve():按token数组中的字符串查表2.1中的前五项(即判别其是否为保留字),若是保留字则返回它的编码,否则返回0值。,(7)retract():扫描指针回退一个字符,同时将character置为空白。(8)buildlist():将标识符登录到符号表或将常数登录到常数表。(9)error():出现非法字符,显示出错信息。相对于图2-5的词法分析器构
13、造如下:,token=;/*对token数组初始化*/s=getchar();getbe();/*滤除空格*/switch(s)case a:case b:case z:while(letter()digit(),concatenation();/*将当前读入的字符送入token数组*/getchar();retract();/*扫描指针回退一个字符*/c=reserve();if(c=0)buildlist();/*将标识符登录到符号表中*/return(id,指向id的符号表入口指针);,elsereturn(保留字码,null);break;case 0:case 1:case 9:wh
14、ile(digit()concatenation();getchar();retract();,buildlist();/*将常数登录到常数表中*/return(num,num的常数表入口指针);break;case+:return(+,null);break;case?:return(?,null);break;case*:return(*,null);,break;case:getchar();if(character=)return(relop,LE);elseretract();return(relop,LT);break;case=:getchar();if(character=),
15、return(relop,EQ);elseretract();return(=,_);break;case;:return(;,_);break;default:error();,2.3 正规表达式与有限自动机简介,2.3.1 正规表达式与正规集 状态转换图对构造词法分析程序是行之有效的,为了便于词法分析器的自动生成,还须将状态转换图的概念加以形式化。正规表达式就是一种形式化的表示法,它可以表示单词符号的结构,从而精确地定义单词符号集。正规表达式简称为正规式,它表示的集合即为正规集。为了理解正规式与正规集的含义,我们以程序语言中的标识符为例予以说明。,程序语言中使用的标识符是一个以字母开头的字
16、母数字串,如果字母用letter表示,数字用digit表示,则标识符可表示为 letter(letterdigit)*其中,letter与(letterdigit)*的并置表示两者的连接;括号中的“”表示letter或digit两者选一;“*”表示零次或多次引用由“*”标记的表达式;(letterdigit)*是letterdigit的零次或多次并置,即表示一长度为0、1、2、的字母数字串;letter(letterdigit)*表示以字母开头的字母数字串,也即标识符集。letter(letterdigit)*就是表示标识符的正规式,而标识符集就是这个正规式所表示的正规集。,对于给定的字母表,
17、正规式和正规集的递归定义如下:(1)和都是上的正规式,它们所表示的正规集分别为和。(2)对任一个a,a是上的一个正规式,它所表示的正规集为a。(3)如果R和S是上的正规式,它们所表示的正规集分别为L(R)和L(S),则:,RS是上的正规式,它所表示的正规集为L(R)L(S);R.S是上的正规式,它所表示的正规集为L(R)L(S);(R)*是上的正规式,它所表示的正规集为(L(R)*;R也是上的正规式,它所表示的正规集为L(R)。,(4)仅由有限次使用规则(1)(3)得到的表示式是上的正规式,它所表示的集合是上的正规集。在上述定义中,规则(1)、(2)为基础规则,规则(3)为归纳规则,规则(4)
18、是界限规则或终止规则。此外,上的一个字是指由中的字符所构成的一个有穷序列;不包含任何字符的序列称为空字,用表示。我们用*表示上所有字的全体,则空字也在其中。例如,若=a,b,则*=,a,b,aa,ab,ba,bb,aaa,。我们还用表示不含任何元素的空集。这里需要注意、和的区别:是由空字组成的集合,而则表示不含任何字的集合。1,正规式间的运算符“”表示或,“”表示连接(通常可省略),“*”表示闭包,使用括号可以改变运算的次序。如果规定“*”优先于“”,“”优先于“”,则在不出现混淆的情况下括号也可以省去。注意,*的正规式R和S的连接可以形式化地定义为 RS=R&S 即集合RS中的字是由R和S中
19、的字连接而成的,且R自身的n次连接记为,我们规定R0=,并令R*=R0R1R2R3,则称R*是R的闭包;此外,令R+=RR*,并称R+是R的正闭包。闭包R*中的每个字都是由R中的字经过有限次连接而成的。对于上的正规式R和S,如果它所表示的正规集L(R)=L(S),则称R和S等价并记为R=S。不难证明,正规式具有下列性质:(1)交换律:RS=SR。(2)结合律:R(ST)=(RS)T;R(ST)=(RS)T。(3)分配律:R(ST)=RSRT;(RS)T=RTST。(4)同一律:R=R=R。,例2.1 令=a,b,设R=a(ab)*是上的正规式,试求其表示的正规集。解答 L(R)=L(a(ab)
20、*)=L(a)L(ab)*)=L(a)(L(ab)*=L(a)(L(a)L(b)*=a(ab)*=aa,b*=a,a,b,aa,ab,ba,bb,aaa,=a,aa,ab,aaa,aab,aba,abb,aaaa,例2.2 判断下述正规式之间是否等价:(1)(ab)*与a*b*(2)(ab)*与a*b*(3)(ab)*与(a*b*)*,解答(1)(ab)*对应的正规集其a、b可任意交替出现,如abbaaaba;而(a*b*)对应的正规集只可出现任意个a或者任意个b;因此两者不等价。(2)(ab)*对应的正规集是以任意个ab对出现的,即ababab;而a*b*对应的正规集则是先出现任意个a后接任
21、意个b,即aabb;因此两者不等价。(3)由于(ab)*对应的正规集其a、b可任意交替出现,如aababbb;而(a*b*)*可采用如下构造方法得到字aababbb:(a*b*)2=(a*b*)0(a2b1)1(a1b3)2=aababbb 反之,对(a*b*)*产生的任意字也可由(ab)*得到,即两者是等价的。,例2.3 证明:设L(a+)=a*?,则有a+=aa*。证明 L(a+)=a*?=,a,a2,a3,?=a,a2,a3,=a,a,a2=aa*=L(a)L(a*)=L(aa*)故 a+=aa*,2.3.2 有限自动机 有限自动机(FA)是更一般化的状态转换图,它分为确定有限自动机DF
22、A和非确定有限自动机NFA两种。1确定有限自动机(DFA)一个确定的有限自动机Md(记为DFA Md)是一个五元组M d=(S,f,s0,Z),其中:(1)S是一个有限状态集,它的每一个元素称为一个状态;(2)是一个有穷输入字母表,它的每一个元素称为一个输入字符;,(3)f是一个从S到S的单值映射,即f(si,a)=sj且有si、sjS和a;(4)s0S,是惟一的一个初态;(5)Z(S,是一个终态集。例如,对图2-6所给出的状态s1有:f(s1,a)=s2 f(s1,b)=s3 f(s1,c)=s4 因此,f是单值映射函数。,图2-6 DFA的状态转换示意,2非确定有限自动机(NFA)一个非确
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 编译 原理 词法 分析

链接地址:https://www.31ppt.com/p-6056770.html