- 1、本文档共69页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第4章
词法分析;4.1 词法分析程序的设计
4.2 单词的描述工具
4.3 有穷自动机
4.4 正规式和有穷自动机的等价性
4.5 正规文法和有穷自动机间的转换
4.6 词法分析程序的自动构造工具;课题:正规文法与正规式及其等价变换
目的要求:
1.理解词法分析在编译过程中的重要性;
2.掌握正规式的定义,正规式与正规文法的等价变换?
教学重点:
1.正规式的定义;
2.正规式与正规文法的等价变换
教学难点 :
正规式与正规文法的等价变换
教学课时: 2
教学方法:多媒体教学
教学内容和步骤 :(如下); 词法分析:是编译过程的第一个阶段,在语法分析前进行。也可以和语法分析结合在一起作为一遍,由语法分析程序调用词法分析程序来获得当前单词供语法分析使用。
主要任务:从左到右逐个字符地对源程序进行扫描,产生一个个单词序列,用以语法分析。并把源程序转换为等价的内部表示形式。;单词是语言中具有独立意义的最小语法单位,包括保留字、标识符、运算符、标点符号和常量等。
词法分析工作独立的原因:
简化设计
改进编译效率
增加编译系统的可移植性 ; 一. 正规文法(回顾)
文法G=(Vn,Vt,P,S),P中每一规则有A→aB或A→a ,A,B?Vn,a?Vt*,称G(S)是正规文法。;几类单词的描述;无符号实数:〈无符号实数〉→ d 〈余留无符号数〉| . 〈十进小数〉| e〈指数部分〉〈余留无符号数〉→ d 〈余留无符号数〉| . 〈十进小数〉| e〈指数部分〉|ε〈十进小数〉 → d 〈余留十进小数〉〈余留十进小数〉 → e〈指数部分〉| d 〈余留十进小数〉| ε〈指数部分〉 → d 〈余留整指数〉| s〈整指数〉〈整指数〉 → d 〈余留整指数〉〈余留整指数〉 → d 〈余留整指数〉 |ε其中s表示正或负号。
如 125.55e+15 和 232.147; 二. 正规式(正则表达式)
是表示正规集的工具,也是用以描述单词符号的方便工具。
正规式表示字符串的格式。正规式r 完全由它所匹配的串集来定义。这个集合称为由正规式生成的语言,写作L(r)。该语言首先依赖于适用的字符集,它一般是A S C I I 字符的集合或它的某个子集。集合的元素称作符号。这个正规符号的集合称作字母表。
可以将正规表达式理解成程序设计语言中的单词的词型公式,它比正规文法更容易让人理解单词是按怎样的规则构成的。;正规式与正规集的定义:
设字母表为Σ,辅助字母表Σ={?,?,|,·,*,(,)} ;
?和?都是Σ上的正规式,表示的正规集分别为{?}和?;
任何a?Σ,a是Σ上的一个正规式,表示的正规集为{a};
假定e1和e2都是Σ上的正规式,它们所表示的正规集分别为L(e1)和L(e2),则(e1),e1|e2,e1·e2和e1*也都是正规式,所表示的正规集分别为L(e1),L(e1)∪L(e2), L(e1)L(e2)和(L(e1))*。; 4. 仅由有限次使用上述三步骤而定义的表达式才是Σ上的正规式,仅由这些正规式所表示的子集才是Σ上的正规集。;正规式;例:令?={d,? ,e,+,-{,则?上的正规式为:
d*(.dd*| ?)(e(+|-|?)dd*|?)表示的是无符号数。
其中d为0~9中的数字。
比如:2,12.59,3.6e2,471.88e-1等都是正规式表示集合中的元素。;4. r(s|t) = rs|rt
(s|t)r = sr|tr
5. ?r=r
r?=r;三. 正规文法到正规式
对于任意一个正规文法,存在一个同一语言的正规式。对每一个正规式,存在一个正规文法。即正规式?正规文法;2. 对形如A→x*y的产生式,重写为:
A→xB
A→y
B→xB
B→y
B为新的非终结符,B? VN;例:将R=a(a|d)*变换成正规文法。令S是文法开始符号。;最后得到正规文法为:;转换规则:
1. A→xB,B→y 正规式为:A=xy
2. A→xA|y 正规式为: A=x*y
3. A→x,A→y 正规式为: A=x|y ;S→ aA
S→ a
A→ aA
A→ dA
A→ a
A→ d;S=a( (a|d)*(a|d)) |a
=a((a|d)*(a|d) | ?)
=a(a|d)*; 词法分析是编译的第一个阶段,它的主要功能是识别单词。
正规式也叫正则表达式,是表示正规集的工具,是单词的词型公式。
对于任意一个正规文法,存在一个同一语言的正规式。对每一个正
您可能关注的文档
最近下载
- 湖南省长沙市长郡雨花外国语学校2022年人教版小升初考试数学试卷(一)(含答案解析).docx VIP
- 福建省福州一中自主招生考试数学试卷.docx VIP
- 《企业内部控制》第18章 内部信息传递.pptx VIP
- 小学英语特色课程.doc VIP
- 肱骨骨折的护理查房.pptx VIP
- 浙江省台州市椒江区2023-2024学年八年级下学期期末数学试题(含答案).docx VIP
- 2025中考初中英语1600单词速记完整版(复习必背).docx
- 2025年哈尔滨供水集团有限责任公司人员招聘笔试备考试题及答案解析.docx VIP
- (正式版)S-H∕T3507-2024 石油化工钢结构工程施工及验收规范.docx VIP
- JT∕T 1094-2016 营运客车安全技术条件.pdf VIP
文档评论(0)