首页 类C语言词法分析器设计文档

类C语言词法分析器设计文档

举报
开通vip

类C语言词法分析器设计文档类C语言词法分析器设计文档 您下载的软件来自:最火软件站 www.veryhuo.com 类C语言词法分析器设计 一、问题描述 词法分析器是编译工作的第一个阶段,主要完成对源程序的扫描,从而将源程序转 换成单词序列,作为第二阶段语法分析的输入。 二、需求分析 1、 预处理:过滤掉跳格符、回车符、换行符等编辑性字符。将多个连续的空格 合并成一个空格。过滤注释。 2、 单词符号的识别,将每个单词符号进行不同类别的划分。单词符号可划分 成5种。 (1) 关键字:如if、else、while、int、flo...

类C语言词法分析器设计文档
类C语言词法分析器 设计 领导形象设计圆作业设计ao工艺污水处理厂设计附属工程施工组织设计清扫机器人结构设计 文档 您下载的软件来自:最火软件站 www.veryhuo.com 类C语言词法分析器设计 一、问题描述 词法分析器是编译工作的第一个阶段,主要完成对源程序的扫描,从而将源程序转 换成单词序列,作为第二阶段语法分析的输入。 二、需求分析 1、 预处理:过滤掉跳格符、回车符、换行符等编辑性字符。将多个连续的空格 合并成一个空格。过滤注释。 2、 单词符号的识别,将每个单词符号进行不同类别的划分。单词符号可划分 成5种。 (1) 关键字:如if、else、while、int、float等。 (2) 标识符:用户自己定义的名字,常量名、变量名和过程名。 (3) 常数:各种类型的常数 (4) 运算符:如+、-、*、<、>、>=等。 (5) 届符:如逗号、分号、括号等。 3、 最后将所有的单词符号转化为便于计算机处理的机内码形式 4、 用户界面使用图形化界面 三、概要设计 1、 字符集说明:本词法分析演示的是C语言的一个子集,字符集如下: (1) 关键字:int,long,float,double,char,short,void,if,else,for,while,do,break,switch, continue,case,default,return,static,struct (2) 运算符:+,-,*,/,%,>,<,=,!=,==,<=,>=,++,--,!,&,&&,||,[] (3) 界符:,,;,{,},(,),:,?,”,# (4) 标识符:以字母开头的字母数字串。 (5) 常数:整型或浮点型。 2、 字符集的内编码形式: 字符 机内编码 字符 机内编码 int 1 = 26 long 2 > 27 char 3 < 28 if 4 ! 29 else 5 == 30 for 6 != 31 while 7 >= 32 return 8 <= 33 break 9 ++ 34 continue 10 -- 35 switch 11 & 36 case 12 && 37 default 13 || 38 float 14 [ 39 double 15 ] 40 void 16 , 41 您下载的软件来自:最火软件站 www.veryhuo.com struc t17 ; 42 static 18 ( 43 do 19 ) 44 short 20 { 45 + 21 } 46 , 22 „ 47 * 23 “ 48 / 24 : 49 % 25 # 50 如果是用户自己定义的标识符则机内码为51; 如果是常数,则机内码为52。 错误则用0表示机内码。 3、 相关变量说明: (1) keyword[]:{"int","long","char","if","else","for","while","return","break", "continue","switch","case","default","float","double","void","struct","static","do","short"}; (2) operater[]:{"+","-","*","/","%","=",">","<","!","==","!=",">=","<=","++","--", "&","&&","||","[","]"}; (3) delimeter[]:{",",";","(",")",",",",","\'","\"",":","#"}; (4) 说明:1--20号为关键字,可直接用下标表示,i+1就是其机内码,21--40为运 --50为界符,直接下标:i+41就是其机内码; 算符,间接下标:i+21就是其机内码, 41 如果是用户自己定义的标识符,则其机内码为51;如果是常数,则其机内码是52;如果是 错误,则机内码为0. 4、 主要类说明: (1) Analysis类:接收源程序,进行词法分析工作,再将分析结果传到用户 界面。 (2) UserFrame类:不参与词法分析工作,只提供用户操作界面。接收用户的输入,并产生输出。 、 主要方法说明: 5 (1)preTreat():预处理,消除跳格符、换行符和回车符,合并空格并消除注释。 (2)doAnalysis():主分析函数,通过调用一系列子函数,完成分析工作并输出 结果。 (3)divide():完成字符的分解,返回一个独立的字符串(可能是关键字、标识 符、运算符、界符或者数字串)。 (4)check():对divide()返回的字符串进行检查,判断其是数字串、单个字符还 是字符串,返回不同标志。1:数字;2:单个字符;3:多个字符 (5)checkDigit():如果check()返回的是数字串,则调用该函数判断其是整型还 是浮点型,返回不同标志。是正常的数字类型则返回常数对应的机内码,否则, 返回错误的机内码。 (6)checkChar():如果check()返回的是单个字符,则调用该函数判断其是标识 符、运算符还是界符,返回其对应的机内码。 (7)checkString():如果check()返回的是字符串,则调用该函数判断其是关键 字、标识符还是运算符,返回其机内码。 您下载的软件来自:最火软件站 www.veryhuo.com 6、 功能调用图: 主程序 preTreatdoAnalysisprintOutdividecheckcheckDigitcheckCharcheckString 四、详细设计 1、String preTreat(String ss): String,ds;int i = 0;char ch,nc;ss for i = 0 to ss.length-1 ch = ss.charAt(i) nc = ss.charAt(i+1) ch == \r||\n||\t||’’TFnc == \r||\n||\t||’’FT ch=’’;ts = ts + ch;continuets = ts + ch; ch == \r||\n||\t||’’TF ts = ts + ch; 2、doAnalysis(String ts): 您下载的软件来自:最火软件站 www.veryhuo.com Source Programs divide() checkString YArrayList Empty?End checkCharN check() checkDigit Print the result 3、ArrayList divide(String ts): ArrayList al; String ts, str; char ch;ch = ts.charAt(i) int i = 0;str àal; ch == ‘ ’str=str+ch;str==””||while i < ts.lengthstr is stringstràal; ch is letter or digitstr =”” otherstr = str + ch; str=str+ch;str==””||otherstr.length==1&&stràal;return al;str+ch is legal str =””otheri++str = str + ch; 4、int check(String st): 您下载的软件来自:最火软件站 www.veryhuo.com c = st.charAt(0) YNc is a digit? YNreturn 1;st.length>1? return 2;return 3; 5、int checkDigit(): Init c char ,i int:=0c = st.charAt(i) continueflag = 0‘0’ 总结 初级经济法重点总结下载党员个人总结TXt高中句型全总结.doc高中句型全总结.doc理论力学知识点总结pdf : (1) 通过本次实验,我们对编译原理中的词法分析的原理和工作过程有了深入的了解。 (2) 对一般的软件开发步骤有了大致的了解,为以后的软件开发工作打下了良好的基础。 (3) 通过本次实验,让我们切实体会到了合作的意义,以及在多人合作的时候怎样处理各成员之间的矛盾和怎样调动各成员的积极性。
本文档为【类C语言词法分析器设计文档】,请使用软件OFFICE或WPS软件打开。作品中的文字与图均可以修改和编辑, 图片更改请在作品中右键图片并更换,文字修改请直接点击文字进行修改,也可以新增和删除文档中的内容。
该文档来自用户分享,如有侵权行为请发邮件ishare@vip.sina.com联系网站客服,我们会及时删除。
[版权声明] 本站所有资料为用户分享产生,若发现您的权利被侵害,请联系客服邮件isharekefu@iask.cn,我们尽快处理。
本作品所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用。
网站提供的党政主题相关内容(国旗、国徽、党徽..)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
下载需要: 免费 已有0 人下载
最新资料
资料动态
专题动态
is_079973
暂无简介~
格式:doc
大小:26KB
软件:Word
页数:0
分类:企业经营
上传时间:2017-11-11
浏览量:14