`

【编译原理】第三章 词法分析

 
阅读更多

一,词法分析器的作用

词法分析是编译的第一阶段。词法分析器主要任务是读入源程序的输入字符、将他们组成词素,生成并输出一个词法单元序列,每个词法单元对应于一个词素。

分析部分:词法分析、语法分析(简化编译器设计、提高编译器效率、增强编译器可移植性)

1)词法单元:词法单元名和可选的属性值组成。关键字、操作符……

2)模式:词法单元词素可能具有的形式,当词法单元是关键字时,模式就是这个关键字的字符序列

3)词素:源程序中的一个字符序列,它和某个词法单元模式匹配。

4)词法错误:识别出某个错误词素,继续判断下一个词素

二,输入缓冲

1)我们至少向前看一个字符,才能判断当前词素是否到头。

2)对付大型源程序,需要处理大量字符。处理往往需要很多时间,我们采用两个交替读入的缓冲区。(详见73)

三,词法单元的规约

1)我们会不会用完缓冲区?通常对于比较长的字符串我们采用 ”+“的形式链接起来。

2)正则表达式:letter_(letter_ | digit) * 表示字母开头 0个或多个 字母或数字

3)正则表达式例子
a | b {a, b}
(a | b) (a | b ) {aa, ab, ba, bb}
aa | ab | ba | bb {aa, ab, ba, bb}
a* 由字母a构成的所有串集
(a | b)* 由a和b构成的所有串集
复杂的例子
( 00 | 11 | ( (01 | 10) (00 | 11) * (01 | 10) ) ) * 01001101000010000010111001

3)正则表达式扩展

1>一个或多个实例 一元后缀算符“+”的意思是“一个或多个实例”,即正规式a+表示一个或多个a的所有串的集合。算符+和算符*有同样的优先级和结合性。代数恒等式 r* = r+ |  和r+ = rr*表达了这两个算符之间的关系。
2>零个或一个实例 一元后缀算符?的意思是“零个或一个实例”,r?是r |  的缩写。如果r是正规式,那么(r)?是表示语言L(r)∪{ }的正规式。使用这两种缩写,可以用num  digit+ (.digit+)? (E (+ | )? digit+)?来描述无符号数。
3>字符组 [abc](其中a、b和c是字母表的符号)表示正规式a | b | c。缩写字符组[az]表示正规式a | b | … | z。使用字符组,可以用正规式[AZaz][AZaz09] *描述标识符。


四,词法单元的识别

某些状态为接受状态或最终状态,表明已经找到一个词素。

1)关系符转换图

2)保留字和标识符转换图


3)无符号树转换图


4)空白转换图



五,词法分析器生成工具 Lex

1)Lex是Unix环境下非常著名的工具,主要功能是生成一个词法分析器(scanner)的C源码,描述规则采用正则表达式(regular expression)。描述词法分析器的文件*.l,经过lex编译后,生成一个lex.yy.c 的文件,然后由C编译器编译生成一个词法分析器。词法分析器,简单来说,其任务就是将输入的各种符号,转化成相应的标识符(token),转化后的标识符 很容易被后续阶段处理

2)用Lex穿件一个词法分析器


3)Lex冲突解决

总是选择最长的前缀,如果最长前缀跟多个模式匹配,总是选择在Lex程序中先呗列出的模式

六,有穷自动机

1)有穷自动机可用作描述在输入串中识别模式的过程,因此也能用作构造扫描程序。当然有穷自动机与正则表达式之间有着很密切的关系

2)有限自动机分成确定的和不确定的两种情况。“不确定”(Nondeterministic Finite Automata ,NFA)的含义是,存在这样的状态,对于某个输入符号,它存在不只一种转换。确定的和不确定的有限自动机都正好能识别正规集,也就是它们能识别的语言正好是正规式所能表达的语言。

3)NFA组成


4)转换表


5)从正则表达式r=(a|b) * abb 到NFA




分享到:
评论

相关推荐

    编译原理第3章 词法分析.pdf

    编译原理是计算机科学中的重要领域,主要研究如何将高级语言转换为机器语言,整个过程分为多个阶段,词法分析是编译过程的第一个阶段。词法分析器负责扫描源程序中的字符序列,然后将其分解成有意义的片段,这些片段...

    编译 原理 第二章 词法 分析 课后 答案

    "编译原理第二章词法分析课后答案" 本文将详细介绍编译原理第二章词法分析的课后答案,涵盖词法分析器、扫描器、非确定有限自动机、确定有限自动机、正规式等概念。 2.1 词法分析器的输出结果是单词的种别编码和...

    编译原理词法分析课件

    ### 编译原理词法分析知识点详解 #### 一、词法分析概述 词法分析是编译过程的第一步,其核心任务是对源程序进行扫描,识别出一系列的单词符号。这一过程涉及到对源程序中字符流的处理,并将其转换为有意义的语法...

    编译原理课程设计词法语法分析器

    在这个“编译原理课程设计词法语法分析器”项目中,我们将探讨编译器的核心组成部分——词法分析器和语法分析器的实现。 首先,词法分析器(也称为扫描器或词法生成器)是编译器的第一个阶段。它的任务是从源代码中...

    编译原理中简单的词法分析器

    根据给定的文件信息,我们可以总结出以下关于“编译原理中简单的词法分析器”的相关知识点: ### 1. 词法分析器的基本概念 词法分析器(也称为扫描器或词法分析程序)是编译器的一个重要组成部分,它的主要任务是...

    编译原理实验报告(词法分析)

    在计算机科学领域,编译原理是一门至关重要的课程,它涉及到如何将高级编程语言转换为机器可理解的二进制代码。本实验报告主要聚焦于编译器的词法分析阶段,这是编译过程的第一步,也是理解源代码的基础。 词法分析...

    编译原理 陈火旺(第三版)第三章 词法分析.ppt

    编译原理 陈火旺(第三版)第三章 词法分析 本章节主要介绍词法分析器的要求、设计和正规表达式与有限自动机的相关知识点。 词法分析器的要求 词法分析器(Lexer)是编译器的第一阶段,负责将源程序分解成单词...

    编译原理手工编写简易词法分析程序

    总结一下,编写一个简易的词法分析程序涉及到理解编译原理的基本概念,掌握C++的输入/输出操作,熟悉正则表达式或状态机的设计,以及良好的错误处理机制。通过实践这个项目,你不仅可以加深对编译原理的理解,还能...

    编译原理实验词法分析语法分析

    这份资料将帮助学习者深入理解词法分析器和语法分析器的设计与实现,通过实际操作加深对编译原理的理解。 总的来说,这个实验旨在让学习者掌握编译器的基本构造块,并运用到实际项目中。通过词法分析器的构建,学生...

    编译原理课程设计(词法分析)

    词法分析是编译原理中的一个关键步骤,它是编译器前端的重要组成部分,负责将源代码转换成一系列的符号或标记(Token)。在这个“编译原理课程设计(词法分析)”项目中,我们将深入探讨词法分析的过程,并通过Java...

    编译原理实验报告,词法分析,语法分析,语义分析。

    词法分析是编译过程的第一步,它将源代码分解成一系列的词法单元,也称为“token”。词法单元是程序中最小的有意义的部分,如关键字、标识符、常量、运算符等。词法分析器通常通过正则表达式来识别这些单元,并生成...

    编译原理实验1——词法分析器设计

    通过阅读和理解这些代码,你可以深入了解词法分析器的工作原理,并动手实践来提升你的编译原理知识。 总之,词法分析器是编译器的关键组件,它的设计直接影响到编译器的效率和错误检测能力。通过这个实验,你可以...

    编译原理 词法分析 编译原理 词法分析

    编译原理是计算机科学中的一个重要领域,主要研究如何将高级编程语言转换为机器可以理解的低级语言,如汇编代码或机器代码。这个过程分为多个阶段,其中一个关键步骤是词法分析,也称为扫描器或者词法分析器的设计与...

    编译原理:第4章 词法分析.pdf

    本资源是关于编译原理的第四章,词法分析的概述。词法分析是编译程序的第一阶段,对源程序进行词法分析,识别出单词符号,并将其转换成长度上统一的标准形式,以供其它部分使用。在本章中,我们将学习词法分析程序的...

    编译原理词法分析,语法分析,语义分析(源代码和实验报告)

    这个过程通常包括三个主要阶段:词法分析、语法分析和语义分析。 词法分析,也称为扫描,是编译器的第一步。它将源代码分解成一系列的最小可识别单位,称为“词法单元”或“标记”。这些词法单元可以是关键字、...

    编译原理实验报告——词法分析器

    在编译原理中,词法分析是编译过程的第一步,它的主要任务是从源程序中提取出有意义的词汇单元,这些词汇单元称为单词,包括标识符、符号和常量等。词法分析器不关注单词在上下文中的正确性,只负责识别和分类。 **...

    编译原理实验二 词法分析

    编译原理实验二 词法分析 本实验报告的主要目的是设计和实现一个词法分析程序,深入理解词法分析的原理,并掌握将源程序扫描为单词的方法。通过实验,掌握词法分析的基本概念和技术,包括词法分析的定义、词法分析...

    编译原理 词法分析器 词法分析器

    词法分析器,又称扫描器或词法分析程序,在编译原理中是编译器的第一阶段,其主要任务是将源代码转换成一系列有意义的符号,即词法单元或标记(Token)。它通过识别并分类输入流中的字符序列,将其转化为后续语法...

    编译原理词法分析

    在Java中,可以使用`java.util.regex`包来进行正则表达式的匹配,或者使用第三方库如ANTLR、JavaCC等来生成词法分析器。这些工具可以自动生成词法分析器的代码,减少手动编写的工作量,并且能够保证分析器的正确性。...

    编译原理课程设计-词法分析器(附含源代码)

    ### 编译原理课程设计-词法分析器 #### 一、设计说明及设计要求 在计算机科学领域,编译器的设计与实现是一项极其重要的任务。编译器负责将高级语言编写的人类可读的源代码转换为机器可执行的目标代码。这一过程...

Global site tag (gtag.js) - Google Analytics