词法分析器的设计与实现
- 格式:doc
- 大小:388.00 KB
- 文档页数:34
词法分析器原理词法分析器(Lexical Analyzer)是编译器中的重要组成部分,用于将输入的源代码分解为一个个词法单元(Token),为语法分析器(Syntax Analyzer)提供分析的基础。
本文将介绍词法分析器的原理和工作流程。
一、概述词法分析器通过扫描源代码字符流,并识别出其中的合法词法单元。
它将源代码转化为一个个标识符、关键字、常数、运算符等基本构件,以供后续阶段进行进一步的处理和分析。
二、工作原理1. 自动机词法分析器通常使用有限自动机(Finite Automaton)来实现。
有限自动机由一系列状态组成,每个状态所接受的输入决定了自动机的状态转移。
利用状态转移规则,自动机可以根据输入字符逐步分析源代码并产生相应的词法单元。
2. 正则表达式为了方便描述词法分析器对输入的词法单元进行匹配,可以使用正则表达式。
正则表达式是一种描述字符模式的工具,它可以定义一类字符串的集合。
词法分析器将正则表达式与状态机相结合,通过模式匹配的方式识别输入字符流中的词法单元。
3. 词法规则词法分析器通过预先定义的词法规则来描述源代码中的不同词法单元。
例如,某个编程语言的词法规则可能包含关键字、标识符、数字、字符串等。
词法规则的定义中常常使用正则表达式来指定某个词法单元的模式。
4. 符号表为了方便后续的语义处理和编译过程,词法分析器通常会维护一个符号表(Symbol Table)。
符号表记录了源代码中出现的标识符、常量等信息,以供后续的语法分析和语义分析使用。
三、工作流程词法分析器的工作流程可以分为以下几个步骤:1. 读取源代码字符流,并初始化状态机。
2. 通过状态转移规则,逐个输入字符进行状态转移,直到达到某个终止状态。
3. 判断当前状态是否为某个词法单元的终止状态,如果是,产生相应的词法单元,并将其记录在符号表中。
4. 继续读取源代码字符流,重复以上过程,直到扫描完整个源代码。
五、总结词法分析器作为编译器的重要组成部分,负责将源代码分解为一个个词法单元,并提供给语法分析器进行进一步的处理。
编译原理实验报告一、实验目的本次编译原理实验的主要目的是通过实践加深对编译原理中词法分析、语法分析、语义分析和代码生成等关键环节的理解,并提高实际动手能力和问题解决能力。
二、实验环境本次实验使用的编程语言为 C/C++,开发工具为 Visual Studio 2019,操作系统为 Windows 10。
三、实验内容(一)词法分析器的设计与实现词法分析是编译过程的第一个阶段,其任务是从输入的源程序中识别出一个个具有独立意义的单词符号。
在本次实验中,我们使用有限自动机的理论来设计词法分析器。
首先,我们定义了单词的种类,包括关键字、标识符、常量、运算符和分隔符等。
然后,根据这些定义,构建了相应的状态转换图,并将其转换为程序代码。
在实现过程中,我们使用了字符扫描和状态转移的方法,逐步读取输入的字符,判断其所属的单词类型,并将其输出。
(二)语法分析器的设计与实现语法分析是编译过程的核心环节之一,其任务是在词法分析的基础上,根据给定的语法规则,判断输入的单词序列是否构成一个合法的句子。
在本次实验中,我们采用了自顶向下的递归下降分析法来实现语法分析器。
首先,我们根据给定的语法规则,编写了相应的递归函数。
每个函数对应一种语法结构,通过对输入单词的判断和递归调用,来确定语法的正确性。
在实现过程中,我们遇到了一些语法歧义的问题,通过仔细分析语法规则和调整函数的实现逻辑,最终解决了这些问题。
(三)语义分析与中间代码生成语义分析的任务是对语法分析所产生的语法树进行语义检查,并生成中间代码。
在本次实验中,我们使用了四元式作为中间代码的表示形式。
在语义分析过程中,我们检查了变量的定义和使用是否合法,类型是否匹配等问题。
同时,根据语法树的结构,生成相应的四元式中间代码。
(四)代码优化代码优化的目的是提高生成代码的质量和效率。
在本次实验中,我们实现了一些基本的代码优化算法,如常量折叠、公共子表达式消除等。
通过对中间代码进行分析和转换,减少了代码的冗余和计算量,提高了代码的执行效率。
实验一词法分析程序设计与实现一、实验目的:加深对词法分析器的工作过程的理解;加强对词法分析方法的掌握;能够采用一种编程语言实现简单的词法分析程序;能够使用自己编写的分析程序对简单的程序段进行词法分析。
二、实验内容:自定义一种程序设计语言,或者选择已有的一种高级语言(C语言),编制它的词法分析程序。
词法分析程序的实现可以采用任何一种编程工具。
三、实验要求:1. 对单词的构词规则有明确的定义;2. 编写的分析程序能够正确识别源程序中的单词符号;3. 识别出的单词以<种别码,值>的形式保存在符号表中;4. 词法分析中源程序的输入以.c格式,分析后的符号表保存在.txt文件中。
5. *对于源程序中的词法错误,能够做出简单的错误处理,给出简单的错误提示,保证顺利完成整个源程序的词法分析;6. 实验报告要求用自动机或者文法的形式对词法定义做出详细说明,说明词法分析程序的工作过程,说明错误处理的实现*。
四、实验学时:12学时五、实验步骤:1. 定义目标语言的可用符号表和构词规则;2. 依次读入源程序符号,对源程序进行单词切分和识别,直到源程序结束;3. 对正确的单词,按照它的种别以<种别码,值>的形式保存在符号表中;4. *对不正确的单词,做出错误处理*。
词法分析(Lexical Analysis) 是编译的第一阶段。
词法分析器的主要任务是读入源程序的输入字符、将他们组成词素,生成并输出一个词法单元序列,每个词法单元对应一个词素。
这个词法单元序列被输出到语法分析器进行语法分析。
知识储备词法单元:由一个词法单元名和一个可选的属性值组成。
词法单元名是一个表示某种词法单位的抽象符号,比如一个特定的关键字,或者代表一个标识符的输入字符序列。
词法单元名字是由语法分析器处理的输入符号。
模式:描述了一个词法单元的词素可能具有的形式。
词素:源程序中的一个字符序列,它和某个词法单元的模式匹配,并被词法分析器识别为该词法单元的一个实例。
题目:词法分析器的设计与实现一、引言................................ 错误!未定义书签。
二、词法分析器的设计 (3)2.1词的内部定义 (3)2.2词法分析器的任务及功能 (3)32.2.2 功能: (4)2.3单词符号对应的种别码: (4)三、词法分析器的实现 (5)3.1主程序示意图: (5)3.2函数定义说明 (6)3.3程序设计实现及功能说明 (6)错误!未定义书签。
77四、词法分析程序的C语言源代码: (7)五、结果分析: (12)摘要:词法分析是中文信息处理中的一项基础性工作。
词法分析结果的好坏将直接影响中文信息处理上层应用的效果。
通过权威的评测和实际应用表明,IRLAS是一个高精度、高质量的、高可靠性的词法分析系统。
众所周知,切分歧义和未登录词识别是中文分词中的两大难点。
理解词法分析在编译程序中的作用,加深对有穷自动机模型的理解,掌握词法分析程序的实现方法和技术,用c语言对一个简单语言的子集编制一个一遍扫描的编译程序,以加深对编译原理的理解,掌握编译程序的实现方法和技术。
Abstract:lexical analysis is a basic task in Chinese information processing. The results of lexical analysis will directly affect the effectiveness of the application of Chinese information processing. The evaluation and practical application show that IRLAS is a high precision, high quality and high reliability lexical analysis system. It is well known that segmentation ambiguity and unknown word recognition are the two major difficulties in Chinese word segmentation. The understanding of lexical analyse the program at compile, deepen of finite automata model for understanding, master lexical analysis program implementation method and technology, using C language subset of a simple language compilation of a scanned again compiler, to deepen to compile the principle solution, master compiler implementation method and technology.关键词:词法分析器?扫描器?单词符号?预处理Keywords: lexical analyzer word symbol pretreatment scanner一、引言运用C语言设计词法分析器,由指定文件读入预分析的源程序,经过词法分析器的分析,将结果写入指定文件。
词法分析器实验报告词法分析器实验报告一、引言词法分析器是编译器中的重要组成部分,它负责将源代码分解成一个个的词法单元,为之后的语法分析提供基础。
本实验旨在设计和实现一个简单的词法分析器,以深入理解其工作原理和实现过程。
二、实验目标本实验的目标是设计和实现一个能够对C语言代码进行词法分析的程序。
该程序能够将源代码分解成关键字、标识符、常量、运算符等各种词法单元,并输出其对应的词法类别。
三、实验方法1. 设计词法规则:根据C语言的词法规则,设计相应的正则表达式来描述各种词法单元的模式。
2. 实现词法分析器:利用编程语言(如Python)实现词法分析器,将源代码作为输入,根据词法规则将其分解成各种词法单元,并输出其类别。
3. 测试和调试:编写测试用例,对词法分析器进行测试和调试,确保其能够正确地识别和输出各种词法单元。
四、实验过程1. 设计词法规则:根据C语言的词法规则,我们需要设计正则表达式来描述各种词法单元的模式。
例如,关键字可以使用'|'操作符将所有关键字列举出来,标识符可以使用[a-zA-Z_][a-zA-Z0-9_]*的模式来匹配,常量可以使用[0-9]+的模式来匹配等等。
2. 实现词法分析器:我们选择使用Python来实现词法分析器。
首先,我们需要读取源代码文件,并将其按行分解。
然后,针对每一行的代码,我们使用正则表达式进行匹配,以识别各种词法单元。
最后,我们将识别出的词法单元输出到一个结果文件中。
3. 测试和调试:我们编写了一系列的测试用例,包括各种不同的C语言代码片段,以测试词法分析器的正确性和鲁棒性。
通过逐个测试用例的运行结果,我们可以发现和解决词法分析器中的问题,并进行相应的调试。
五、实验结果经过多次测试和调试,我们的词法分析器能够正确地将C语言代码分解成各种词法单元,并输出其对应的类别。
例如,对于输入的代码片段:```cint main() {int a = 10;printf("Hello, world!\n");return 0;}```我们的词法分析器将输出以下结果:```关键字:int标识符:main运算符:(运算符:)运算符:{关键字:int标识符:a运算符:=常量:10运算符:;标识符:printf运算符:(常量:"Hello, world!\n"运算符:)运算符:;关键字:return常量:0运算符:;```可以看到,词法分析器能够正确地将代码分解成各种词法单元,并输出其对应的类别。
词法分析程序的设计与实现方法1:采用C作为实现语言,手工编制一.文法及状态转换图1.语言说明:C语言有以下记号及单词:(1)标识符:以字母开头的、后跟字母或数字组成的符号串。
(2)关键字:标识符集合的子集,该语言定义的关键字有32个,即auto,break,case,char,const,continue,default,do,double,else,enum, extern,float,for,goto,if,int,long,register,return,short,signed,static, sizeof,struct,switch,typedef ,union,unsigned ,void, volatile和while。
(3)无符号数:即常数。
(4)关系运算符:<,<=,==,>,>=,!=。
(5)逻辑运算符:&&、||、!。
(6)赋值号:=。
(7)标点符号:+、++、-、--、*、:、;、(、)、?、/、%、#、&、|、“”、,、.、{}、[]、_、^等(8)注释标记:以“/*”开始,以“*/”结束。
(9)单词符号间的分隔符:空格。
2.记号的正规文法:仅给出各种单词符号的文法产生式(1)标识符的文法id->letter ridrid->ε|letter rid|digit rid(2)无符号整数的文法digits->digit remainderremainder->ε|digit remainder(3)无符号数的文法num->digit num1num1->digit num1|. num2|E num4|εnum2->digit num3num3->digit num3|E num4|εnum4->+digits|-digits|digit num5digits->digit num5num5->digit num5|ε(4)关系运算符的文法relop-> <|<=|==|>|>=|!=(5)赋值号的文法assign_op->=(6)标点符号的文法special_symbol->+|-|*|%|#|^|(|)|{|}|[|]|:|;|”|?|/|,|.& (7)逻辑运算符的文法logic->&&| || | !(8)注释头符号的文法note->/starstar->*3.状态转换图其中,状态0是初始状态,若此时读入的符号是字母,则转换到状态1,进入标识符识别过程;如果读入的是数字,则转换到状态2,进入无符号数识别过程;……;若读入的符号是/,转换到状态11,再读入下一个符号,如果读入的符号是*,则转换到状态12,进入注释处理状态;如果在状态0读入的符号不是语言所定义的单词符号的开始字符,则转换到状态13,进入错误处理状态。
词法分析器的设计与实现
1.定义词法规则:根据编程语言的语法规范,定义不同的词法规则,
如关键字、标识符、操作符、常量等。
每个词法规则由一个正则表达式或
有限自动机来描述。
2.构建有限自动机:根据词法规则,构建一个有限自动机(DFA)来
识别词法单元。
有限自动机是一种形式化模型,用于在输入字符序列上进
行状态转换。
3.实现状态转换函数:根据有限自动机的定义,实现状态转换函数。
状态转换函数接受一个输入字符,并返回当前状态和输出的词法单元。
4.实现输入缓冲区:为了方便词法分析器的实现,通常需要实现一个
输入缓冲区,用于存储源代码,并提供一些读取字符的函数。
5. 实现词法分析器:将前面实现的状态转换函数和输入缓冲区结合
起来,实现一个完整的词法分析器。
词法分析器可以使用迭代器模式,每
次调用next(函数来获取下一个词法单元。
6.处理错误情况:在词法分析过程中,可能会遇到一些错误情况,如
未定义的词法单元、不符合语法规范的词法单元等。
词法分析器需要能够
检测并处理这些错误情况。
7.构建测试用例:为了验证词法分析器的正确性,需要构建测试用例,包括各种不同的源代码片段,并验证分析结果是否符合预期。
8.进行性能优化:词法分析是编译器中的一个耗时操作,因此可以进
行一些性能优化,如使用缓存机制、减少状态转换次数等。
以上是词法分析器的设计与实现的一般步骤,具体实现过程可能因编程语言和编译器的不同而有所差异。
词法分析器实验报告一、实验目的本实验旨在通过构建一个简单的词法分析器来加深对编译原理中词法分析的理解,并掌握基本的词法分析算法和程序设计技巧。
二、实验环境操作系统:Windows 10编程语言:C/C++开发环境:Visual Studio 2019三、实验内容1. 设计并实现一个词法分析器,要求具备以下功能:(1)能够识别并区分关键字、标识符、字符常量、字符串常量、整型常量和浮点型常量等基本单词;(2)能够跳过注释、空格、制表符和换行符等无用字符;(3)能够给出错误提示并指明错误所在位置。
2. 对设计的词法分析器进行测试,并记录测试结果,分析测试结果的正确性和效率。
四、实验方法1. 分析待处理的源程序,并确定需要识别的词法单元;2. 设计状态转换图或状态转换表,并将其转化为程序代码;3. 开发测试程序,对所设计的词法分析器进行测试。
五、实验结果1. 实现的词法分析器程序可以正确识别出源程序中的各个单词,并能够跳过无用字符;2. 在测试过程中发现了一些错误,比如未能正确识别一些特殊情况下的单词,或者给出了错误的错误提示等。
经过修改后,程序可以正确识别这些情况,并给出正确的错误提示信息;3. 程序的效率较高,能够在短时间内对源程序进行词法分析。
六、实验体会通过本次实验,我对编译原理中词法分析的概念、算法和程序设计技巧有了更加深入的了解和掌握。
在实践中,我遇到了许多问题,比如如何设计状态转换图,如何正确识别一些特殊的单词等。
这些问题一一解决后,我对词法分析有了更加深刻的理解。
通过本次实验,我还深刻体会到了编译器设计过程中的思维方式和技术要求。
编译器是计算机科学中的一项重要技术,对于提高程序运行效率、保证程序安全性、增强程序可读性和扩展程序功能等都有重要作用。
因此,编译原理作为计算机科学的重要组成部分,对于我以后的学习和研究具有重要意义。
目录一.设计题目 (2)二.设计要求 (2)1. 词法分析器的定义 (2)2. 设计要求 (2)3. 本程序自行规定: (3)三.设计作用与目的 (4)1. 设计作用 (4)2. 设计目的 (4)四.运行环境及工具软件 (4)五.系统设计 (5)1. 系统总体设计 (5)(1)词法分析器的设计 (5)(2)总体设计框图 (6)(3)总程序流程图 (6)2. 各子模块设计 (8)(1)字符的识别 (8)(2)关键字的识别 (8)(3)数字的识别 (8)(4)界符的识别 (10)(5)运算处理 (10)3.相关函数分析 (11)4. 源程序设计 (12)六.实验调试结果 (29)1. 调试工具 (29)2. 调试步骤 (29)3. 调试结果 (29)七.设计中的问题及解决方法 (31)八.设计心得 (32)九.参考文献 (34)词法分析器的设计与实现一.设计题目词法分析器的设计与实现二.设计要求1. 词法分析器的定义词法分析顾名思义就是分词。
它以程序设计语言编制的源程序作为输入,以单词序列作为输出。
分词过程可以通过编制程序自动完成,我们通常称这个分词程序为词法分析器。
词法分析器分析的源程序可以是现有的各类程序设计语言源程序也可以是人为给定的模型语言的源程序。
本文中的源程序为后者。
从词的角度来看,它涉及的内容较为简单,只包括几个较为常用的词类,词类的构成上也适当的作了一些简化。
对词进行分析时,我们是按类型进行分析的。
不同类型的词在后续的分析中所起的作用不同,相应的操作也各有不同,但同种类型中的词虽然单词的构成不同但从宏观上看它们的操作大体一致。
模型语言中的单词可以分为“关键字”、“标识符”、“常数”、“分隔符”、“运算符”几类。
一般,关键字在程序设计语言中人为给定2. 设计要求对给定的程序通过词法分析器能够识别一个个单词符号,并以二元式(单词种别码,单词符号的属性值)显示。
而本程序则是通过对给定路径的文件的分析后以单词符号和文字提示显示。
另外,如果是算术表达式,则需要通过栈、运算符的优先级比较处理等从而计算出最终结果并显示。
通过此次课程设计要求掌握从源程序文件中读取有效字符的方法,掌握词法分析的实现方法并上机调试编出的词法分析程序。
在处理表达式前,首先设置两个栈:一是运算符栈,用于在表达式处理过程中存放运算符。
在开始时,运算符栈中先压入一个表达式结束符“#”。
二是操作数栈,用于在表达式处理过程中存放操作数。
然后从左到右依次读出表达式中的各个符号(运算符或操作数),每读出一个符号按以下原则进行处理:(1)若读出的是操作数,则将该操作数压入操作数栈,并依次读入下一个符号。
(2)若读出的是运算符,则作进一步判断。
①若读出运算符的优先级大于运算符栈顶运算符的优先级,则将读出的运算符压入运算符栈,并依次读下一个符号。
②若读出的是表达式结束符“#”,且运算符栈栈顶的运算符也是表达式结束符“#”,则表达式处理结束,最后的计算结果在操作数栈的栈顶位置。
③若读出运算符的优先级不大于运算符栈栈顶运算任的优先级,则从操作数栈连续退出两个操作数,并从运算符栈退出一个运算符,然后作相应的运算(运算符为刚从运算符栈退出的运算符,运算对象为刚从操作数栈退出的两个操作数),并将运算结果压入操作栈。
3. 本程序自行规定:⑴关键字:"auto","break","case","char","const","continue","default","do","double","else","enum","extern","float","for","goto","if","int","long","return","short","signed","sizeof","static","struct","switch"……⑵运算符:"+","-","*","/","="……⑶界符:"{","}","[","]",";",",",".","(",")",":"⑷数字:'0'~'9'⑸其他标记如字符串,表示以字母开头的标识符。
⑹空格、回车、换行符跳过。
在屏幕上显示如下:( +, 运算符)( ;, 界符)(auto , 关键字)( 1 , 无符号整数)( a , 普通标识符)(continue , 关键字)三.设计作用与目的1. 设计作用用高级语言编写一个词法分析器,使之能识别输入串,并把分析结果(单词符号,标识符,关键字等等)输出。
输入源程序,输入单词符号,本词法分析器可以辨别关键字、标识符、常数、运算符号和某些界符,运用了文件读入来获取源程序代码,再对该源程序代码进行词法分析,这就是词法分析器的基本功能。
当词法分析器调用预处理子程序处理出一串输入字符放进扫描缓冲区之后,分析器就从此缓冲区中逐一识别单词符号。
当缓冲区里的字符串被处理完之后,它又调用预处理子程序来处理新串。
2. 设计目的1)熟悉词法分析的基本原理,词法分析的过程,以及词法分析中要注意的一些问题;2)通过设计调试词法分析程序,实现从源程序中分出各种单词的方法;3)复习高级语言,进一步加强用高级语言来解决实际问题的能力;4)提高词法分析方法的实践能力;5)理解如何理论联系实际以及明白理论与实际的差别。
四.运行环境及工具软件Windows XP环境,Microsoft visual C++ 6.0版,512M内存,80G硬盘容量。
VC++是微软公司开发的一个IDE(集成开发环境),换句话说,就是使C++的一个开发平台.有些软件就是这个编出来的vc++是Windows平台上的C++编程环境,学习VC要了解很多Windows平台的特性并且还要掌握MFC、ATL、COM等的知识,难度比较大。
五.系统设计1. 系统总体设计(1)词法分析器的设计词法分析在教学上的主要应用是对源程序进行分词同时验证词的合性,词法分析的输入是给定的模型语言,输出为单词序列。
输入的源程序可以看成是一个字符串序列,通过把源程序看作字符串序列就可以采用形式语言的一些现有理论处理相关的编译题。
分词的输出为单词序列,单词是一个有共同含义的字符集。
由于程序设计语言中通常使用空格来分割不同的词,因此初学者在理解这一概念时可以简单的把空格分隔开的字符串认为是一个单词。
词法分析器设计时,输入的源程序以文件的形式存储在外部。
主控程序通过打开文件调用待分析的源程序。
程序设计时采用一字一码的形式处理,标志符为一类,不同的标志符通过值区别。
常数只给出具体的值即可。
根据以上的分析可以相应的设计如下的存储结构。
关键字可以设计为一个预先存储好的表格。
其设计的主要思路为:先让用户输入单词或字符串,而且是一个字一个字的读取,直到#束,且要全部打印出代码。
着便开始进行分析,先是依次判断每一个字符,空白就跳到下一个,次往下类推,道不是空白为止。
后再读入一个字符,如果是字母,就继续读入下一个,只要遇到是字母或者是数字的时候,都继续往下读,而且读入的字符都依次地保存在一个字符串当中,直到不是字母或者是数字为止。
这时侯来查找关键字表,如果有关键字的话,则作为关键字输出,如果没有,就作为字符串输出。
的话,如果是数字,也继续读入,如果是数字或者是小数点,依然继续往下读,也依次保存在字符串中,直到不是数字或小数点为止,最终这里得到就是常数。
要注意的是,在这里如果中途遇到运算符和界符,也依然要做和前面关键字、字符串或者是常数类似的分析,如果输入是一个正确的算术表达式则按照如下操作进行:(1)若读出的是操作数,则将该操作数压入操作数栈,并依次读入下一个符号。
(2)若读出的是运算符,则作进一步判断。
①若读出运算符的优先级大于运算符栈顶运算符的优先级,则将读出的运算符压入运算符栈,并依次读下一个符号。
②若读出的是表达式结束符“#”,且运算符栈栈顶的运算符也是表达式结束符“#”,则表达式处理结束,最后的计算结果在操作数栈的栈顶位置。
③若读出运算符的优先级不大于运算符栈栈顶运算任的优先级,则从操作数栈连续退出两个操作数,并从运算符栈退出一个运算符,然后作相应的运算(运算符为刚从运算符栈退出的运算符,运算对象为刚从操作数栈退出的两个操作数),并将运算结果压入操作栈。
这就是整个词法分析器的设计思想。
(2)总体设计框图总体设计框图如下:图1.总体设计框图(3)总程序流程图总程序流程图如下:图2.总体流程图2. 各子模块设计(1)字符的识别判断输入的字符是否为字符,若为字符则将其拼凑成一个单词在往下进行判断,若不为字符则则判断其是否为数字,其子模块程序流程图1如下:(2)关键字的识别判断输入的单词是否为关键字,若为关键字则返回它的编码,若不为关键字则判断其是否为运算符,其子模块程序流程图如图2所示:(3)数字的识别判断输入的字符是否为数字,若为数字则返回它的编码,若不为数字则判断其是否为运算符,其子模块程序流程图如图3所示:(4)界符的识别判断输入的字符是否为界符,若为数字则break,若不为数字则将搜索指示器回调一个字符位置,将ch置为空白字符,其子模块程序流程图如下所示:(5)运算处理3.相关函数分析⏹int i=0,j=0,k=0,t=0; //搜索指示器⏹char ch; //存放最新读入的原程序字符⏹void GetChar(); //将下一个字符读入ch中,搜索指示器前移一字符位⏹void GetBC(); //检查ch中的字符是否为空白,若是则调用Getchar直至ch中进入一个非空白字符⏹void Concat(); //将ch中的字符连接到strToken之后⏹bool IsLetter(); //判断ch中的字符是否为字符bool IsDigit(); //判断ch中的字符是否为数字int Reserve(); //对strToken中的字符串查找保留字表,若它是一个保留字●则返回它的编码,否则返回-1值。