词法分析器又称扫描器。词法分析是指将我们编写的文本代码流解析为一个一个的记号,分析得到的记号以供后续语法分析使用。
中文名称 | 词法分析器 | 原 理 | 已知文法利用递归向下分析 |
---|---|---|---|
主要特点 | 不依靠语法,而只依靠词法 | 别 称 | 扫描器 |
词法分析器主要特点是不依靠语法,而只依靠词法,即处理一个单词时不依赖于外部单词的信息,因此词法分析器一般都很简单。当然,对某些语言在作词法分析时,在有些情况下不得不往前查看多个字符,有时还要做一些特殊处理,还有一些在词法分析中处理不了的,要留到语法分析中进行处理。
本算法主要利用状态转换图生成一个词法分析器,对输入的程序进行词法分析,并将分析得到的单词造表。其中关键字表和界限符表的大小是由高级语言的子集决定的,可以用数组装载;而标识符表和常数表的大小取决于输入的待分析程序中的变量、过程名、常数的个数,所以要用指针组成动态链表来装载。当然为了方便,我们也把它定义成数组处理。
语法分析时,调用词法分析器,根据已知文法利用递归向下分析,检查语法错误。
词法分析器基本定义
词法分析器又称扫描器。词法分析是指将我们编写的文本代码流解析为一个一个的记号,分析得到的记号以供后续语法分析使用。词法分析器的工作是低级别的分析:将字符或者字符序列转化成记号.。在谈论词法分析时,使用术语"词法记号"(简称记号)、"模式"和"词法单元"表示特定的含义。
在分析时,一是把词法分析器当成语法分析的一部分,另一种是把词法分析器当成编译程序的独立部分。在前一种情况下,词法分析器不断地被语法分析器调用,每调用一次词法分析器将从源程序的字符序列拼出一个单词,并将其Token值返回给语法分析器。后一种情况则不同,词法分析器不是被语法分析器不断地调用,而是一次扫描全部单词完成编译器的独立一遍任务。
类型1、磁分析器包括单聚焦型和双聚焦型。经加速后的离子束在磁场作用下飞行轨道发生不同程度的弯曲而分离。双聚焦质谱仪的分辨率可达150000;2、飞行时间分析器飞行时间分析器被加速的离子按不同的的时间经...
库伦水分仪又名微量水分测定仪电极污染及保养,电极是微量水分测定仪的关键部件,要避免微量水分测定仪电极污染及保养就尤为重要;微量水分测定仪电极表面的污染可直接导致灵敏度降低,有些电极长期应用于油质样品的...
套一个垫层、一个找平层、一个面砖面层子目就行了。 5厚的不用单独计算,单独计算一下20厚的找平层吧。 砂浆品种是可以换算的。
针对当前私家车辆剧增,交通问题日益严重,本系统采用J2EE技术以Java CV开源计算机视觉库技术为基础,设计并完成一套在流媒体图像中定位行驶过程中的车辆牌照,并将其从图像中提取出来,实现在流媒体中进行车牌检索的功能,并具有车辆流量分析功能的系统。
陶瓷环高阻膜作为简镜分析器避免边缘电场效应的重要部件,其质量对电子能量分析器的性能有很大影响,本文介绍了在陶瓷环上采用适当地分层蒸镀Cr膜和老化处理,制成时间稳定和温度稳定的高阻膜,经测试性能良好,并已实用于俄歇电子谱仪中。
一种能生成词法分析程序的自由软件。可替代UNIX操作系统中的Lex词法分析器生成器。
《计算机科学技术名词 》第三版。
第1章
引论
1.2SPL语言的特点及实验安排
1.2.1SPL语言的特点
1.2.2SPL语言编译器的主要结构
1.2.3实验安排
1.3平台的选择和介绍
1.3.1LEX简介
1.3.2YACC简介
第2章
词法分析
2.2词法分析器的基本原理
2.2.1DFA的构造和实现
2.2.2词法分析的预处理
2.2.3实现词法分析器的注意要点
2.3词法分析器的实现
2.3.1SPL语言单词属性字
2.3.2SPL词法分析器的输入和输出
2.3.3SPL词法分析器的分析识别
第3章
语法分析
3.1语法分析的基本框架
3.1.1上下文无关文法
3.1.2语法分析过程
3.1.3语法分析过程中的数据结构
3.2语法分析的基本方法
3.2.1自顶向下的分析方法
3.2.2自底向上的分析方法
3.3语法分析的实现
3.3.1SPL语法定义
3.3.2SPL语法分析
第4章
符号表实现
4.1符号表的操作及数据结构
4.1.1符号表的操作
4.1.2符号表的数据结构
4.2基本原理和设计要点
4.2.1作用域规则
4.2.2设计要点
4.3SPL符号表的实现
4.3.1符号表的组织方式
4.3.2符号表的具体实现
第5章
错误处理
5.1错误处理基本原理
5.1.1错误的种类
5.1.2错误的诊察和报告
5.1.3错误处理技术
5.1.4错误处理实现中的要点
5.2错误处理的实现
5.2.1错误处理数据结构定义和相关函数
5.2.2词法错误处理
5.2.3语法错误
5.2.4语义错误
5.2.5限制重复报告错误
第6章
代码生成
6.1代码生成原理及主要数据结构
6.1.1技术概述
6.1.2主要数据结构
6.2代码生成的关键要点
6.2.1布尔表达式的代码生成
6.2.2条件语句的代码生成
6.2.3循环结构的代码生成
6.2.4程序调用的代码生成
6.3目标机器环境说明
6.3.1目标机器8086
6.3.2目标机器i386
6.4代码生成程序的实现
6.4.1定义与声明的翻译
6.4.2表达式的翻译
6.4.3语句和控制流的翻译
第7章
代码优化
7.2基本原理
7.2.1代码优化分类
7.2.2常量表达式优化
7.2.3公共表达式的优化
7.2.4循环优化
7.2.5优化实现的要点
7.3优化的实现
7.3.1常量合并的实现
7.3.2公共表达式节省的实现
第8章
SPL编译器完整实现
8.2编译器各部分接口
8.2.1词法分析
8.2.2语法分析
8.2.3语义分析
8.2.4#间代码生成
8.2.5代码优化
8.2.6目标代码生成
8.2.7错误处理
8.3语言的扩充和实现
8.3.1词法分析器的语言扩充
8.3.2语法分析器的语言扩充
8.3.3符号表的语言扩充
8.3.4树和DAG扩充
8.3.5目标代码生成的语言扩充
8.5编译器的编译和测试
8.5.1Linux环境下的编译和运行
8.5.2Windows环境下的编译和运行