编译原理第3章
编译原理第03章PPT课件
65
-
procedure swap(var x:integer); begin x:=x+a; /*a是全局变量*/
a:=x-a; x:=x-a end; 调用swap(a);别名也影响编译器生成优化的代 a:=(x-y*z)+w ; b:=(x-y*z)+u ; 若a与x、y或z中任一个是别名
用标号控制循环体 DO 7 I=1,10 A(I)=0 B(I)=0
7 CONTINUE
19
-
②Pascal的for 语句
计数重复的值可在任何有序集上 for . . . to . . . for . . . down to . . .
20
-
2. 条件制导
①while:0次或多次重复 ②do-while,repeat-until:多次重复 ③ALGOL 68循环的一般形式:
Smalltalk 语言以对象方式来处理控 制结构。
40
-
可以认为上述语言是可扩充的,用 户可以通过定义新的(抽象)数据类型 和控制结构来扩充基本语言。
但基本的控制结构并没有发生改变。
41
-
第二节 单元级控制结构
规定程序单元之间控制流程的机制。 最简单的机制是 ALGOL60 的分程序
42
-
在程序顺序执行的过程中,遇到一 个分程序,就建立一个新的引用环境, 并执行这个分程序。
7
-
3. 多选一 嵌套 的 if then else
if语句包含if语句 ①ALGOL 60的选择结构引起二义性
if x>0 then if x<6 then x:=0 else x:=9 ②PASCAL的“最近匹配原则” ③ ALGOL 68中if语句的结束符号fi ④ ALGOL 68对else if 进行缩写
《编译原理》第3章
NFA到相应的DFA的构造的基本思路是: DFA的每 一个状态对应NFA的一组状态. DFA使用它的状 态去记录在NFA读入一个输入符号后可能达到的 所有状态.
NFA M所能接受的符号串的全体记为L(M)
结论:
上一个符号串集V是正规的,当且仅当存 在一个上的不确定的有穷自动机M,使得 V=L(M)。
DFA是NFA的特例.对每个NFA N一定存在一个DFA M,使得 L(M)=L(N)。对每个NFA N存在着与之 等价的DFA M。 有一种算法,将NFA转换成接受同样语言的DFA.这 种算法称为子集法. 与某一NFA等价的DFA不唯一.
0
1
S P
Z
{P} {}
{P}
{S,Z} {Z}
{P}
• δ为S * 到S的子集(2 S)的一种映射
• 从NFA的矩阵表示中可以看出,表项通常是一状态的集合, 而在DFA的矩阵表示中,表项是一个状态
∑*上的符号串t被NFA M接受:
• 对于Σ*中的任何一个串t,若存在一条从某一初态 结点到某一终态结点的道路,且这条道路上所有 弧的标记字依序连接成的串(不理采那些标记为ε 的弧)等于t,则称t可为NFA M所识别(读出或接 受)。 • 若M的某些结点既是初态结点又是终态结点;或 者存在一条从某个初态结点到某个终态结点的道 路,其上所有弧的标记均为ε,那么空字ε可为M所 接受。
其中: δ(S,0)={P}
δ(S,1)={S,Z} δ(Z,0)={P} δ(Z,1)={P} δ(P,1)={Z} • 状态图表示
1 1 S 0 0,1 Z
P
1
• 矩阵表示
状态 输入
δ(S,0)={P} δ(S,1)={S,Z} δ(Z,0)={P} δ(Z,1)={P} δ(P,1)={Z}
编译原理第三章
例3.4 Z→ A→ B→
有正规文法G: 0A 0A | 0B 1A | ε
例3.5 A→ B→ C→
有正规文法G: aB | bB aC | a | b aB
例3.6 Z→ U→ V→
有正规文法G: Z=0(0|01)*0 U0 | V1 A=(a|b)(aa)*(a|b) Z1 | 1 Z=(10|01)(10|01)* Z0 | 0
A
B
r2 ε
A C
A
B
ε
B
r1
④R为复合正规式?
例3.12 3.13 P41
教学进度
3.4.4 NFA确定化为DFA
方法(子集法) 1、改造M为M’: ①引进新的初态结点X、终态结点Y; ②对M的状态转换图实施分裂(替换)
计算机科学与工程系
2、将M’进一步变换为DFA :
①状态子集T的闭包_CLOSURE(T) ②定义状态集Ta = _CLOSURE(J) ③从DFA的初态_CLOSURE({X})开始计算状态转换矩阵;直到 不再产生新的状态子集为止。
第三章
• • • • • •
词法分析与有穷自动机
计算机科学与工程系
词法分析器的功能与输出 单词符号的两种定义方式 正规表达式与有穷自动机 正规文法与有穷自动机 词法分析器的设计 词法分析程序自动构造工具LEX简介
教学进度
3.1 词法分析器的功能
计算机科学与工程系
词法分析:对字符串表示的源程序进行从左到右的扫描和 分解,根据语言的词法规则识别出一个个具有独立意义的 单词符号。
教学进度
3.3 单词符号的两种定义方式
单词符号结构的描述方法:
计算机科学与工程系
正规文法(3型文法)(regular grammar)
编译原理第三章_有穷自动机
例 过河问题 分析(续)
初始状态:MWGC-φ;终止状态:φ-MWGC。 g
MWGC-φ
WC-MG
问题:
6
例 过河问题 状态转换图
起始 g
MWGC-φ g
g φ-MWGC
g
7
WC-MG
m
m MWC-G
w
w
c
C-MWG
c W-MGC
g
g
MGC-W c
MG-WC
w
m
c G-MWC
m
gg MWG-C
+dd. ddd;
输入符号串
数字 数字
SB
.
数字
+
A
H
-.
数字
.G
接收:若扫描完输入串, 且在一个终止状态上结 束。
数字 阻塞:若扫描结束但未 停止在终止状态上;或 者为能扫描完输入串 (如遇不合法符号)。
不完全描述:某些状态 对于某些输入符号不存 在转换。
练习:+34.567 .123 3.4.5
w
有穷自动机(FA)
数字系统:可以从一个状态移动到另一个状态;每次 状态转换,都上由当前状态及一组输入符号确定的;可以 输出某些离散的值集。
FA:一个状态集合;状态间的转换规则;通过读头来 扫描的一个输入符号串。
读头:从左到右扫描符号串。移动(扫描)是由状态 转换规则来决定的。
8
读头
一个FA的例子
(3)运行: 串f(,Q,且t1tt21)∈= Σf(,f(Qt1,t2t1∈), Σt2*),其中Q∈K, t1t2为输入字符
17
例3
题:试证abba可为例1的DFA M所识别(所接受)。
编译原理第3章文法和语言
第3章文法和语言第1题文法G=({A,B,S},{a,b,c},P,S)其中P为:S→Ac|aBA→abB→bc写出L(G[S])的全部元素。
答案:L(G[S])={abc}第2题文法G[N]为:N→D|NDD→0|1|2|3|4|5|6|7|8|9G[N]的语言是什么?答案:G[N]的语言是V+。
V={0,1,2,3,4,5,6,7,8,9}N=>ND=>NDD....=>NDDDD...D=>D......D或者:允许0开头的非负整数?第3题为只包含数字、加号和减号的表达式,例如9-2+5,3-1,7等构造一个文法。
答案:G[S]:S->S+D|S-D|DD->0|1|2|3|4|5|6|7|8|9第4题已知文法G[Z]:Z→aZb|ab写出L(G[Z])的全部元素。
答案:Z=>aZb=>aaZbb=>aaa..Z...bbb=>aaa..ab...bbbL(G[Z])={anbn|n>=1}第5题写一文法,使其语言是偶正整数的集合。
要求:(1)允许0打头;(2)不允许0打头。
答案:(1)允许0开头的偶正整数集合的文法E→NT|DT→NT|DN→D|1|3|5|7|9D→0|2|4|6|8(2)不允许0开头的偶正整数集合的文法E→NT|DT→FT|GN→D|1|3|5|7|9D→2|4|6|8F→N|0G→D|0第6题已知文法G:<表达式>::=<项>|<表达式>+<项> <项>::=<因子>|<项>*<因子><因子>::=(<表达式>)|i试给出下述表达式的推导及语法树。
(5)i+(i+i)(6)i+i*i答案:(5)<表达式>=><表达式>+<项>=><表达式>+<因子>=><表达式>+(<表达式>)=><表达式>+(<表达式>+<项>)=><表达式>+(<表达式>+<因子>)=><表达式>+(<表达式>+i)=><表达式>+(<项>+i)=><表达式>+(<因子>+i)=><表达式>+(i+i)=><项>+(i+i)=><因子>+(i+i)=>i+(i+i)(6)<表达式>=><表达式>+<项>=><表达式>+<项>*<因子>=><表达式>+<项>*i=><表达式>+<因子>*i=><表达式>+i*i=><项>+i*i=><因子>+i*i=>i+i*i<表达式><表达式>+<项><因子><表达式><表达式>+<项><因子>i<项><因子>i<项><因子>i()<表达式><表达式>+<项><项>*<因子><因子>i<项><因子>ii第7题证明下述文法G[〈表达式〉]是二义的。
编译原理_第3章课件
编译原理_第3章课件第三章词法分析本章将讨论词法分析程序的设计原则,单词的描述技术,识别机制及词法分析程序的⾃动构造原理。
教学要求1.掌握:正规式,DFA的概念,NFA的概念2.理解:将NFA转换为DFA ,正规式、正规⽂法与有穷⾃动机间的转换⽬录3.1 词法分析程序的设计3.2 单词的描述⼯具3.3 有穷⾃动机3.4 正规式与有穷⾃动机的等价性3.5 正规⽂法和有穷⾃动机的等价性3.6 词法分析程序的⾃动构造⼯具⼩结3.1.词法分析(lexical analysis)程序的设计回顾:1、词法分析的任务:逐个读⼊源程序字符并按照构词规则切分成⼀系列单词。
2、词法分析程序:实现词法分析的程序。
⼀.词法与语法分析程序的接⼝⽅式1、作为独⽴的⼀遍词法分析是编译过程中的⼀个阶段,在语法分析前进⾏,把字符流的源程序变为单词序列,输出在⼀个中间⽂件上。
2、与语法分析结合在⼀起作为⼀遍⼀般、把词法分析程序设计成⼀个⼦程序,由语法分析程序调⽤词法分析程序来获得当前单词,供语法分析使⽤。
….词法分析程序的主要任务:读源程序,产⽣单词符号词法分析程序的其他任务:滤掉空格,跳过注释、换⾏符追踪换⾏标志,复制出错源程序,宏展开,……⼆、词法分析程序的输出输出是单词符号。
单词是语⾔中具有独⽴意义的最⼩单位。
单词包括:保留字标识符常量运算符界符(标点符号)词法分析程序所输出的单词符号常常采⽤以下⼆元式表⽰:(单词种别,单词⾃⾝的值)。
单词的种别是语法分析需要的信息,⽽单词⾃⾝的值则是编译其它阶段需要的信息。
(标识符,指向该标识符所在符号表中位置的指针) 单词的种别可以⽤整数编码表⽰,假如标识符编码为1,常数为2,保留字为3,运算符为4,界符为5例如:程序段if i=5 then x∶=y;在经词法分析器扫描后输出的单词符号和它们的表⽰如下:- 保留字if(3,'if')- 标识符i(1,指向i的符号表⼊⼝)- 等号=(4,'=')- 常数5(2,'5')- 保留字then(3,'then')- 标识符x(1,指向x的符号表⼊⼝)- 赋值号∶=(4,'∶=')- 标识符y(1,指向y的符号表⼊⼝)- 分号;(5,';')三、词法分析⼯作从语法分析⼯作独⽴出来的原因:简化设计改进编译效率增加编译系统的可移植性3.2 单词的描述⼯具程序设计语⾔中的单词是基本语法成分.单词符号的语法可以⽤有效的⼯具加以描述,并且基于这类描述⼯具,实现词法分析程序的⾃动构造.描述⼯具:正规⽂法和正规式识别⼯具:有穷⾃动机⼀.正规⽂法多数程序设计语⾔的单词的语法能⽤正规⽂法来描述。
编译原理 第三章
• ε-Closure(q): 从状态q出发,经过任意条标记为ε的矢线所能达到的状态集合。
• f^的递归定义: 1)f^(s,ε)=ε- Closure(s) 2)f^(s,wa)=ε- Closure(p) 其中:p=f(f^(s,w),a)=∪f(q,a), q∈f^(s,w) 3)f(R,a)=∪f(q,a), q∈R (将f的定义域推广到状态集合R) 4)f^(R,w)=∪f^(q,w), q∈R (将f^的定义域推广到状态集合R)
2)有限自动机所接受符号串的递归定义(将f的定义域推广到 k x ∑*) (1) f^(s,ε)=s; (2) f^(s,aw)=f^(f(s,a),w),a∈∑,w∈∑* 结论:f^与f效果一样。
3)一个DFA M所接受的字符串的全体称为M的接受集或语言,记为: L(M)={x|f(S0, x)∈Z, x∈∑*}。
最优 (优先顺序可用括号加以改变) 次之 最后
• 正规式:将文法的终结符号用以上三种运算符连接起来组成的正规文法的表 达式,是另一种用于描述正规文法的直观表示。 例如语法范畴<标识符>的正规表达式为:字母(字母|数字)* • 正规集:正规式所描述的字符串的集合。
1. 正规表达式和正规集定义:
设∑为一字母表,则∑上的正规式及其所表征的正规集可递归地定义为:
第三章
词法分析及词法分析程序
§3.1 设计扫描器时应注意的几个问题
1. 词法分析阶段的必要性
1)与语法分析比较,可采用简单有效的方法; 2)词法分析有时需要涉及上下文,与语法分析不同; 3)编译程序各部分的功能更加单一,结构清晰,编写、调试相对简单。 注:在逻辑功能上把词法分析和语法分析划分开; 在程序编制(执行流程)上可将词法分析作为语法分析程序的子程序
程序设计语言编译原理(第三版)第3章
程序设计语言编译原理(第三版)第3章第3章词法分析任务:从左至右逐个字符地对源程序进行扫描,产生一个个的单词符号,把作为字符串的源程序改造成为单词符号串。
§3.1§3.2§3.3§3.4对于词法分析器的要求词法分析器的设计正规表达式与有限自动机词法分析器的自动产生(LE某)—略1§3.1对于词法分析器的要求一.功能和输出形式二.接口设计§3.1对于词法分析器的要求一.功能和输出形式1.功能:输入源程序,输出单词符号2.单词符号的分类(1)关键字:由程序语言定义的具有固定意义的标识符,也称为保留字或基本字。
例如:Pacal语言中begin(2)标识符:用来表示各种名字。
endifwhile等。
如变量名、数组名、过程名等。
(3)常数:整型、实型、布尔型、文字型等例:100(5)界符:,;3.14159()true等ample(4)运算符:+、-、某、/3§3.1对于词法分析器的要求3.输出的单词符号形式二元式:(单词种别,单词符号的属性值)通常用“整数编码”“单词符号的特征或特性”单词符号的编码:标识符:一般统归为一种常数:常按整型、实型、布尔型等分类关键字:全体视为一种/一字一种运算符:一符一种界符:一符一种4§3.1对于词法分析器的要求例:考虑下述C++代码段:while(i>=j)i--;经词法分析器处理后,它将被转换为如下的单词符号序列:<while,-><(,-><id,指向i的符号表项的指针><>=,-><id,指向j的符号表项的指针><),-><id,指向i的符号表项的指针><--,-><;,->§3.1对于词法分析器的要求二.接口设计1.词法分析器作为独立的一遍词法分析字符流(源程序)单词序列(输出在一个中间文件上)2.词法分析器作为一个独立的子程序,但并不一定作为独立的一遍语法分析器单词(至少一个)调用(取下一个单词)词法分析器优点:使整个编译程序的结构更简洁、清晰和条理化.6§3.2词法分析器的设计一.输入和预处理二.单词符号的识别三.状态转换图及其实现§3.2词法分析器的设计一.输入、预处理1.预处理:剔掉空白符、跳格符、回车符、换行符、注解部分等.原因:编辑性字符除了出现在文字常数中之外,在别处的任何出现都无意义.#注解部分不是程序的必要组成部分,它的作用仅在于改善程序的易读性和易理解性.8§3.2词法分析器的设计2.预处理子程序:每当词法分析器调用时,就处理出一串确定长度(如120个字符)的输入字符,并将其装进词法分析器所确定的扫描缓冲区中。
编译原理第3章
1、说明:
• 有限自动机是具有离散输入输出系统的数学模型。它具 有有限数目的内部状态,系统可以根据当前所处的状态 和面临的输入字符决定系统的后继行为。其当前状态概 括了过去输入处理的信息
输入带
a b
c d
读头
e ……
有限状态控制器
2014-5-22 12
3.1 正规文法与有限自动机
• 二、有限自动机
电梯是典型的有限状态自动机 那电梯如何描述呢? 电梯的程序又如何构造呢?
2014-5-22
13
3.1 正规文法与有限自动机
• 二、有限自动机-分别讲解
2、确定有限自动机(DFA)
• 确定有限自动机DFA是一个五元组 M(S,,f,s0,Z),其中:
• 1. 取I0=S0 • 2. 若状态集Q中有状态Ii={s0,s1,……sj} , sk∈S , 0 kj;而 且M机中有f({s0,s1,……sj},a)= f(s0,a)∪f(s1,a)…∪f(sj,a) ={s0,s1,……st} =It,若It不在Q中,则将It加入Q。 • 3. 重复第(2)步,直至Q中没有新的状态加入 • 4.取终态F={I | I ∈ Q,且I ∩ Z }
例:已知正规文法G1的产生式,求出它所定义的正规式。
产生式为:SaS|aB BbB|bA AcA|c
• 解:由产生式写出对应的联立方程组: S=aS|aB ( 1) B=bB|bA ( 2) A=cA|c ( 3) 运用定理2求解(1)(2)(3): …
2014-5-22
11
3.1 正规文法与有限自动机
• 注意:
– 仅由字母表A={ai| i=1,2,……n}上的正规式所组成的语言 称作正规集,记作L() – 利用正规集相同,可用来证明相应正规式等价 – “|”读作为“或”,也可写作为“+”或“,”;“•”读作 连接
编译原理课件第3章
代码优化
代码优化的目的和分类
目的
提高程序运行效率,减少空间占用,提高可读 性。
局部优化
对单个程序块的优化,如基本块的优化。
全局优化
对整个程序的优化,如循环优化、死代码删除等。
代码优化的主要技术
常量折叠和替换
将常量表达式的结果在编译时计算出来,并 用结果替换掉表达式。
循环优化
编译原理课件第3章
contents
目录
• 词法分析 • 语法分析 • 中间代码生成 • 代码优化 • 目标代码生成
01
CATALOGUE
词法分析
词法分析器的任务
将源程序分解成一系列的记号(tokens) 去除源程序中的注释和空白符
识别出关键字、标识符、常量、操作符等记号 为语法分析器提供有序的记号流
通过改变循环的迭代顺序、减少循环中的计 算等方法来提高循环的效率。
死代码删除
删除永远不会被执行到的代码。
函数内联
将小的函数调用替换为函数体的直接执行, 以减少函数调用的开销。
代码优化的实现
编译器前端
负责将源代码转换成中间表示(IR),这一阶段主要 完成语义分析和语法分析。
编译器中端
对中间表示进行优化,如常量折叠、死代码删除等。
考虑文法的二义性
有些文法具有二义性,即一种语法结构可以有多种解析方 式。在设计语法分析器时需要考虑如何处理二义性问题, 避免产生错误的分析结果。
语法分析器的实现
编写词法分析器
词法分析器是将输入的字符串转 换成一个个的单词或符号,供语 法分析器使用。在实现语法分析 器之前,需要先编写词法分析器 。
实现递归下降分析
解析与语义分析
编译原理Chapter 3
如:A={a,b} ,B={c,d},则AB = {ac,ad,bc,bd} 如:A={ab} ,B={c,d}, 则AB = {abc,abd}
prev next 10
dir
(star closure)使用 * 表 示 上的一切符号串(包括ε )组成的集 合。Σ *称为Σ 的闭包。 正闭包 (positive closure)上的 除ε 外的所有符号串组成的集合记为+ 。 Σ +称为Σ 的正闭包。
prev next 20
*
y 当且仅当 x=y 或 x
+
y
dir
句型
如果有 S x ,其中S是文法的开始 符,则称x为句型 * 句子 如果有 S x ,且x中不包含非终结 * 符( x VT ),则称x为句子
例如3.1 文法G=(VN,VT,P,S),其中 VN={S},VT={0,1},P={ S→0S1, S→01 } S,0S1,1S0,00S11,000111是句型还是句 子?
结论:我是大学生的构成符合上述规则,它是一个句子
prev
我大学生是不符合上述规则,它不是句子
6
nextΒιβλιοθήκη 3.1 文法的直观概念dir
这些规则成为我们判别句子结构合法与否的
依据,换句话说,这些规则看成是一种元语 言,用它描述汉语。这里仅仅涉及汉语句子 的结构描述。这种描述语言称为 文法 使用文法作为工具的优点
prev
| a | 1
| ab | 2
| | 0
9
next
dir
集合
(set)若集合A中的一切元素都是 某字母表上的符号串,则称A为该字母表上 符号串的集合 集合的乘积 (product)设A、B是符号 串集合,则用AB表示集合的乘积
编译原理 第3章 词法分析与有穷自动机(第5-8讲)
它所对应的状态表如图:
状态 0 1 2 3 a 1 3 1 3 后继 状态 b 2 2 3 3
输入字符 接受 否 否 否 是
式的转化
22
第3章 词法分析与有穷自动机
■DFA所识别的语言
给定DFA M,对于字符c1,c2,…,cn,当以下条件成立时, 称M接受由c1,c2,…,cn组成的字符串c1c2…cn: 存在状态序列s0,s1,s2,…,sn,使得s1=f(S,c1), s2=f(s1,c2),…,sn=f(sn-1,cn),且sn∈Z。 由DFA M接受的语言L(M)是所有M接受的字符串组成的集 合。
25
第3章 词法分析与有穷自动机
判断下图是DFA还是NFA的状态转换图,并 写出其他2种表示形式
26
第3章 词法分析与有穷自动机
■由正规表达式R构造NFA
1.基本正规表达式 (a)对于正规式φ,所构造NFA: (b)对于正规式ε,所构造NFA: (c)对于正规式a,a∈Σ,则 NFA:
x ε y
练习:若S=a|bb,则L((a|bb)*)=?
5
第3章 词法分析与有穷自动机
■正规式中运算的优先级
括号优先,* 次之,•(连接)再次之,| 最后 例:a|bc* ≌ a|(b(c*)) ab|c*d ≌ (ab)|((c*)d)
■ 正规式与正规集举例
L(a|bc*)=L(a)∪L(bc*) 思考:L(ab|c*d)=? =L(a)∪L(b)L(c*) =L(a)∪L(b)(L(c))* ={a}∪{b}{ε,c,cc,ccc……} ={a,b,bc,bcc,bccc,……}
17
第3章 词法分析与有穷自动机
■有穷自动机的状态转移图表示方法
编译原理第三版 第三章 词法分析
超前搜索
例:FORTRAN语言中关键字的识别: DO99K=1,10 识别DO为关键字要搜 DO99K=1.10 索到“,” FORTRAN语言中常数的识别:
5.EQ.M, 5.E08
识别5为常数要搜索到Q
2、状态转换图
大多数程序设计语言中单词符号的词法规则可 以用正规文法描述。如: <标识符>→ 字母|<标识符>字母|<标识符>数字 <整数>→数字|<整数>数字 <运算符>→+|-|×|÷„ <界符>→; |, |( | )|„
#
3.3 正规表达式与有限自动机
目的: 形式化地描述词法规则和词法分析程序 词法分析程序的自动生成 主要内容 正规式与正规集 确定有限自动机 (DFA) 非确定有限自动机(NFA) 正规式与有限自动机的等价性 确定有限自动机的化简
正规文法
多数程序设计语言单词的语法都能用正规文法 (3型文法)描述 正规文法回顾 文法的任一产生式α→β的形式都为
单词符号的种类
(3) 常数 常数的类型一般有整型、实型、布 尔型、字符型等。
(4) 运算符 如 +,-,*,/等,对具体语言个 数是确定的。 (5) 界符 如 , ;()等,对具体语言个数是 确定的。
单词符号的表示形式
词法分析器所输出的单词符号常常表示成如下的 二元式:<单词种别,单词符号的属性值> 单词种别:由语法分析阶段使用的抽象符号。如: 用整数编码。 最简单的编码方案为一类一码,种别编码可设为: 1,2,3,4,5。 另一种编码方案(如本教材中): 标识符:列为一种,用一个整数编码表示; 常数:按类型分种编码; 关键字、运算符、界符:采用一字一种编码。
编译原理 第3章
3.1.3 识别标识符的若干约定和策略
定义标识符的语法规则为 <标识符>→<字母>∣<标识符><字母>∣<标识符><数字> 从语法上来说,标识符的长度似乎可以任意。 然而,考虑实现技术,许多语言都对标识符的最大允许长度作 了限制。
编译原理
7
设计扫描器时,按如下原则行事: 1. 如果一个标识符中的字符个数超过最大允许长度,则把尾部 多出的字符截去; 2. 对于字符个数不超过最大允许长度的标识符,则按“尽可能 长”的策略来识别标识符。
图3.5 状态图
首先,在开始状态R下扫描的第一个符号是0,转到状态 V,表示0是句柄,归约到V。接下来,在状态V扫描1, 转到状态S,此时句柄为V1,归约成S。再往下扫描1,由 状态S转到状态U,表示句柄为S1归约为U。最后,扫描0, 转到状态S,此时句柄为U0,归约为S,
编译原理 27
图3.6(a)列出分析的每一步。形成图3.6(b)所示的语法 树。 自底向上的分析。
读入a1,沿矢线方向到下一状态,在此状态时扫 描a2,……, 直至W中全部字符读完且进入终态F,则W已被接受。
编译原理 19
例:下面的状态图对于串baabba的识别 S→aA|bB,A→bB|aD|a,B→aA|bD|b,D→aD|bD|a|b
a
A a a
a
S b
b
B
a
D b a,b b Z
编译原理
16
E d
d 0
d
d
d 5 d 6
1
.
d
2
E
4
±
. 图3.4文法G<无符号数>的状态图
编译原理 - 陈火旺版 - 第三章
f(V,a)=U f(V,b)=Q f(Q,a)=Q f(Q,b)=Q
S U V Q
a U Q U Q
b V V Q Q
21
确定有限自动机(DFA)
• 状态转换图
f(S,a)=U f(V,a)=U
f(V,b)=Q f(Q,a)=Q f(Q,b)=Q U b b a a a,b S Q b
3
3.1 词法分析器的要求
• 输入:源程序 • 输出:单词符号
– 单词是语言中具有独立意义的最小单位 – 分类
• 基本字:具有固定意义的标识符,
– 如Pascal中, begin, end
• 标识符:变量名、数组名、过程名等 • 常数:分为整型、实型、布尔型等
– 如 100, 0.8, TRUE
• 运算符:+、-、*、/等 • 界符:逗号,分号,括号等
24
非确定有限自动机(NFA)
• NFA: Nondeterministic Finite Automata • 定义:NFA M=S,,δ,S0,F,其中S为状态 的有限集, 为有穷字母表,δ为S * 到 S的子集(2 S)的映射,S0S是初始状态 集,F S为终止状态集。
25
NFA vs. DFA
一个确定有限状态自动机 DFA 是一个五元组 M = (S, ,δ,S0, F ).
有限状态集
有限输入符号集
转移函数 一个开始状态
δ : S S
S0 S FS
26
一个终态集合
NFA vs. DFA
一个非确定有限状态自动机 NFA 是一个五元组 M = (S, ,δ,S0, F ).
22
f(S,b)=V f(U,a)=Q f(U,b)=V a
编译原理第三章-Read
词法分析的基本概念 正规式自动机和状态图 词法分析程序的设计
1
学习目标:
掌握:词法分析程序的构造,正规式和正 规文法到有穷自动机的转换,NFA到DFA的 转换、DFA的化简
理解:正规文法、正规式、DFA的概念、 NFA的概念
了解:词法分析程序的自动构造工具
2
词法分析程序
A→(a|d)A A→ε
A→aA A→dA
最终有产生式: S→aA , A→ ε, A→aA, A→dA
30
2. 将正规文法转换成正规式 将每条产生式改写为正规式
用代入法解正规式方程组
最后只剩下一个开始符号定义的正规式,其中 不含非终结符
正规文法到正规式的转换规则:
文法产生式 正规式
规则1 A→xB B→y A=xy
分配律
5。 r=r, r=r
是“连接”的恒等元素
6。 rr=r r=rrr… “或”的抽取律
25
程序中的单词都能用正规式来定义
令l为a~z的字母,d为0~9的数字
e1= l ( l | d)* e2= dd*
e1表示标识符集合 e2表示无符号整数
注(比较): <标识符>→l|l<字母数字> <字母数字>→l|d|l<字母数字>|d<字母数字>
多含有一个终结符为止
原产生式 变换后产生式
规则1 A→xy A→xB B→y 规则2 A→x*y A→xA A→y 规则3 A→x|y A→x A→y
其中B为一新非终结符
29
例: 将R=a(a|d)*转换成相应的正则文法 令转换成文法G=(VN,VT,P,S) 其中VT={a,d}, 文法开始符为S 首先形成S→a(a|d)*,然后变换 S→aA A→(a|d)*
编译原理第三章
一个句子的表示:羊吃草 <句子> => <主语><谓语> => <名词><谓语> => 羊<谓语> => 羊<动词><直接宾语> => 羊吃<直接宾语> => 羊吃<名词> => 羊吃草 利用上述的规则,可以生成很多句子:“马吃 草”,“他喂马”等,而“羊草吃”不符合上述 规则,不是句子。这些规则称为我们判别句子结 构是否合法的依据,换句话说,这些规则看成是 一种源语言,用来描述汉语。这里仅仅涉及汉语 句子的描述。其中一种描述源语言称为文法。 “草吃羊”也是上述规则生成的一个合法的句子,
第3章 文法和语言 教学要求: 1、掌握:文法的概念,语言的定义, 符号串,文法的形式定义,0型文法, 1型文法,2型文法,3型文法 2、理解:自上而下与自下而上的分析 方法 3、了解:上下文无关文法的ε 规则
预备知识 1、一个程序设计语言是一个记号系统, 其完整定义应包括语法和语义两个方面 2、语法是一组规则,用它可以形成和产 生一个合法的程序,定义什么样的符号 序列是合法的,与符号的含义无关 3、语义是一组规则,定义程序语言的含义 如类型匹配,变量作用域等
编译原理课件第3章有穷自动机
确定性有穷自动机 (DFA)
1
定义
DFA 是有穷自动机的一种,用于表示确定性状态自动机,它从一个状态转移到 另一个状态,每次只读入一个输入字符。
2
应用
在编译原理的词法分析中,DFA 可帮助语法分析器DFA 可以使用状态表或状态图来实现。
非确定性有穷自动机 (NFA)
定义
NFA 是有穷自动机的一种,其中一个状态可以 有多个后继状态,并且可以从一个状态转移到 多个状态。
应用
在词法分析中,NFA 可以解决正则表达式匹配 问题,同时也被用于编程语言中的语法分析。
有穷自动机的应用
词法分析
在编写编译器时,有穷自动机可以用来进行词法分析,从而将源程序转换成更易于处理和理 解的单词串。
计算理论
有穷自动机是计算理论中的重要概念,被广泛应用于机器学习、人工智能和计算机科学的许 多领域。
有穷自动机
编译原理课件第3章介绍有穷自动机,这是一种数学模型,用于描述自动的计 算过程。有穷自动机是编译原理中非常重要的概念。
有穷自动机概述
1 定义
有限状态机,又称有穷状态自动机。它是一个表示有限个特定状态及在这些状态之间的 转移和动作等行为的数学模型。
2 应用
有穷自动机在计算机科学中很有用,例如编写正则表达式、词法分析和语法分析。
状态图
有穷自动机可以使用状态图来表示,通常包括起始状态、接受状态、状态转移和输入字母表。
有穷自动机的分类
有限状态自动机
这是大多数情况下使用的模型,用于表示有穷状 态自动机,由确定性自动机和非确定性自动机两 种类型。
无限状态自动机
用于表示无限状态自动机,由部分确定性自动机 和无限确定性自动机两种类型。
有穷自动机的定义
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
s的一个后继状态
④ s0∈S,唯一的初态 ⑤ F⊆S,是一个终态集(可空)
§3.3正规表达式与有限自动机
2、DFA的两种表达方式 (1)状态转换矩阵
例:DFA M=({0,1,2,3},{a,b},δ,0,{3})
其中δ为: δ(0,a)=1 δ(0,b)=2
δ(1,a)=3 δ(1,b)=2
δ(2,a)=1 δ(2,b)=3 δ(3,a)=3 δ(3,b)=3
§3.3正规表达式与有限自动机
例题:
A、已知字母表∑={a,b,c},试求在该字母表上的仅包括
一个b的所有串的集合相对应的正规式 (a|c)*b(a|c)* B、已知字母表∑={a,b,c},若集合是包括了最多一个b的 所有串,求其相应的正规式 (a|c)*(b|ε)(a|c)*
§3.3正规表达式与有限自动机
标识符:一般统归为一种
常数:常按整型、实型、布尔型等分类 关键字:全体视为一种/一字一种 运算符:一符一种 界符:一符一种
§3.1对于词法分析器的要求
例:考虑下述C++代码段:while ( i >= j ) i - -;
经词法分析器处理后,它将被转换为如下的单词 符号序列: < while , - > <(,-> < id ,指向i的符号表项的指针> <>=,-> < id ,指向j的符号表项的指针> <),-> < id ,指向i的符号表项的指针> <--,-> <;,->
④ GetBC
⑤ Concat
子程序过程,检查ch中的字符是否为空白。若是,
则调用GetChar直至ch中进入一个非空白字符。 子程序过程,将ch中的字符连接到strToken之后.
§3.2词法分析器的设计
⑥ IsLetter和IsDigit 布尔函数过程,它们分别判断ch中的 字符是否为字母和数字。 ⑦ Reserve 整型函数过程,对strToken中的字符串查找 保留字表,若它是一个保留字则返回它的编码,否则 返回0值(假定0不是保留字的编码)。 ⑧ Retract 子程序过程,将搜索指示器回调一个字符位置, 将ch置为空白字符。 ⑨ InsertId 整型函数过程,将strToken中的标识符插入
§3.3正规表达式与有限自动机
3、例题 例.程序设计语言中的几类单词可用下述规则描述: <标识符>l|l <字母数字> <字母数字>l|d|l<字母数字>|d<字母数字> <无符号整数>d|d<无符号整数> <运算符>+|_|*|/|=|<=|>= | = | < | > <界符>,|;|(|)|……
§3.3正规表达式与有限自动机
3、等价:若两个正规式所表示的正规集相同,则认 为二者等价
两个等价的正规式U和V,记为U=V
例: b(ab)*=(ba)*b (a|b)*=(a*b*)* (a*b*)*=(a|b)* L(a*b*)*=[(L(a))*∪(L(b))*]*={ε,a,b,aa,bb,........}*={ε,a,b,ab,...} L(a|b)* ={a,b}*={ε,a,b,ab,…}
结点到某一终态结点的通路,且这条通路上所有弧
的标记符连接成的字等于α。则成α可为DFA M所识 别(接受/读出)。
若M的初态结点同时又是终态结点,则空字ε可为M所识别/接
受。
DFA M所能识别的字的全体记为L(M)。 若一个DFA M的输入字母表为∑,则称M是∑上的一个DFA。
a
0
1
b a
2
a
3
a,b
§3.1对于词法分析器的要求
一、功能和输出形式
1、功能:输入源程序,输出单词符号 2、单词符号的分类 (1)关键字:由程序语言定义的具有固定意义的标识符,也
称为保留字或基本字。 例如:Pascal 语言中 begin (2)标识符:用来表示各种名字。
end
if
while 等。
如变量名、数组名、过程名等。
正规式 ba* a(a|b)*
(a|b)*(aa|bb)(a|b)*
正规集 ∑上所有以b为首后跟任 意多个a的字 ∑上所有以a为首的字 ∑上所有含有两个相继的 a或两个相继的b的字
§3.3正规表达式与有限自动机
B、令∑={A,B,0,1},则: 正规式 (A|B)(A|B|0|1)* 正规集 ∑上的“标识符”的全体 ∑上的“数”的全体
一、输入、预处理
1、预处理:剔掉空白符、跳格符、回车符、换 行符、注解部分等.
原因:
编辑性字符除了出现在文字常数中之外,在别
处的任何出现都无意义.
注解部分不是程序的必要组成部分,它的作用 仅在于改善程序的易读性和易理解性.
§3.2词法分析器的设计
2、预处理子程序: 每当词法分析器调用时,就处理出一串确定长 度(如120个字符)的输入字符,并将其装进词法 分析器所确定的扫描缓冲区中。
(3)常数:整型、实型、布尔型、文字型等 例:100 (5)界符: , ; 3.14159 ( ) true 等 sample (4)运算符:+、-、*、/
§3.1对于词法分析器的要求
3、输出的单词符号形式 二元式:(单词种别,单词符号的属性值)
通常用“整数编码”
“单词符号的特征或特性”
单词符号的编码:
§3.1对于词法分析器的要求
二、接口设计
1、词法分析器作为独立的一遍
词法分析
字符流 (源程序)
单词序列 (输出在一个中间文件上)
2、词法分析器作为一个独立的子程序,但并不 一定作为独立的一遍
语法分析器
单词 调用(取下一个单词)
词法分析器
优点:使整个编 译程序的结构更 简洁、清晰和条 理化.
§3.2词法分析器的设计
(0|1)(0|1)*
一个正规式的正规集与之完全等价,只是表达形式不同
§3.3正规表达式与有限自动机
2、运算
“|”(或):表示从各选择对象中选择
“•”(连接积):表示“连接”起来
(*)(闭包):任意有限次的自重复连接 注: ∞ n S*=∪ S ={ε} ∪S∪SS∪……
n=0
L(r*)=L(r)* 优先级:* > • > ”|”
la~z中的任一英文字母;d0~9中的任一数字
§3.3正规表达式与有限自动机
二、确定有限自动机DFA (Deterministic Finite Aufomofa)
1、DFA M是一个五元式 M=(S,∑,δ ,S0,F)
其中:
① S——有限集,其中的每个元素称为一个状态 ② ∑——有穷字母表,其中的每个元素称为一个输入字符 ③ δ:S×∑S (即∀状态S∈S,a∈∑,δ(S,a)唯一的确定下一状态) δ(s,a)=s‟:当现行状态为s,输入字符为a时,将转换到下一状态s‟
§3.3正规表达式与有限自动机
例题:
A、L(r|s)
L(rs)
=L(r) ∪L(s)={r} ∪{s}={r,s}
=L(r) L(s)={r} {s}={rs} L((a|b)c)=L(a|b) L(c)={a,b}{c}={ac,bc} B、L((a|b)*)={ε,a,b,aa,ab,ba,bb,…} L(a|(b*))={ε,a,b,bb,bbb,…} C、a|bc* —— a|(b(c*)) ab|c*d —— (ab)|((c*)d)
b
2
a
a
3
a,b
b DFA M:
b
m个状态:图中有 个状态结点; n个输入符号: 每个结点顶多有 条箭弧射出; 每条箭弧用∑中的一个 (相同/不同) 输入字符作标记; 整张图含有 个初态结点和若干个 (可为0)终态结点.
§3.3正规表达式与有限自动机
3、识别(读出/接受) 对于任何∑*中的任何字α,若存在一条从初态
§3.2词法分析器的设计
扫描缓冲区的两个指示器:
一个指向当前正在识别的单词的开始位置(即新
单词的首字符) 起点指示器 一个用于向当前搜索以寻找单词的终点搜索指示器
起点指示器
搜索指示器
图 _ 源程序输入缓冲区的对半互补结构
§3.2词法分析器的设计
二. 单词符号的识别——超前搜索
1.关键字的识别
第3章 词法分析
任务:从左至右逐个字符地对源程序进行扫 描,产生一个个的单词符号,把作为 字符串的源程序改造成为单词符号串。
内容简介:
§3.1 对于词法分析器的要求 一.功能和输出形式 二.接口设计 §3.2 词法分析器的设计 一.输入和预处理 二.单词符号的识别 三.状态转换图及其实现 §3.3 正规表达式与有限自动机 一.单词符号的描述 1. 正规式与正规集 2. 正规文法 二.有限自动机 1.DFA 2.NFA 3. NFA与DFA的等价 4. DFA的化简 三.正规式与有限自动机的等价性 四.正规文法与有限自动机的等价性 §3.4 词法分析器的自动产生(LEX) —— 略
字母或数字
i
其它
j
§3.2词法分析器的设计
C、例 课本43页图3.3;45--46页
§3.3正规表达式与有限自动机
一、正规式,正规集,正规文法 二、确定有限自动机(DFA)
三、非确定有限自动机(NFA)
四、NFA=>DFA=>化简 五、正规式有限自动机 六、左线性正规文法有限自动机 左线性正规文法有限自动机
符号表,返回符号表指针。
⑩ InsertConst 整型函数过程,将strToken中的常数插入 常数表,返回常数表指针。
§3.2词法分析器的设计
B、示例
字母
j k l
i
数字
/
图中结点i所对应的程序段可表示为: GetChar (); if ( IsLetter( ) ) {…状态j的对应程序段…;} else if ( IsDigit( ) ) {…状态k的对应程序段…;} else if ( ch=„/‟ ) {…状态l的对应程序段…;} else {…错误处理…;} 图中结点i所对应的程序段可表示为: GetChar (); while (IsLetter ( ) or IsDigit ( ) ) GetChar ( ); …状态j的对应程序段…