编译技术实验报告材料词法分析报告程序

上传人:cn****1 文档编号:510531986 上传时间:2022-12-01 格式:DOCX 页数:17 大小:142.74KB
返回 下载 相关 举报
编译技术实验报告材料词法分析报告程序_第1页
第1页 / 共17页
编译技术实验报告材料词法分析报告程序_第2页
第2页 / 共17页
编译技术实验报告材料词法分析报告程序_第3页
第3页 / 共17页
编译技术实验报告材料词法分析报告程序_第4页
第4页 / 共17页
编译技术实验报告材料词法分析报告程序_第5页
第5页 / 共17页
点击查看更多>>
资源描述

《编译技术实验报告材料词法分析报告程序》由会员分享,可在线阅读,更多相关《编译技术实验报告材料词法分析报告程序(17页珍藏版)》请在金锄头文库上搜索。

1、实用文档编译技术实验报告实验名称:词法分析程序姓名:和春辰学号:U200818016软件工程0801班指导老师:胡福林2010年10月21日目录、实验题目2、实验目的2三、实验要求2四、实验步骤3基本设计思路3流程框图3算法设计4函数相关说明5输入与输出7程序运行结果7五、实验方案设计实现8六、实验程序亮点描述8七、实验程序使用说明8八、实验心得体会8九、源程序清单8实验题目标识符、设计、编制、调试一个识别一简单语言单词的词法分析程序。程序能够识别基本字、无符号整数、浮点数、运算符和界符)。单词符号及种别表如下:单词符号种别编码begin1if2the n3while4do5end6l(l|d

2、)*10dd*11+13-14*15/1617:=18202123=24=2526(27)28#0二、实验目的设计、编制并调试一个词法分析程序,加深对词法分析原理的理解。实验要求词法分析程序需具备词法分析的功能:输入:所给文法的源程序字符串。(字符串以“ #”号结束)输出:二元组(syn,token 或sum)构成的序列。其中:syn为单词种别码;toke n为存放的单词自身字符串;sum为整型常数。例如:对源程序begin x:=9: if x9 then x:=2*x+1/3; end #输出如下序列:(1,begi n)(10,x)(18,:=)(11,9)(26,;)(2,if)的源文

3、件,经过词法分析后四、实验步骤基本设计思路基本字作为一类特殊的标识符来处理:识别出标识符,差基本字表,给出相应种别码。(字基本字表置初值:char *rwtab6=begin,if,then,while,do,end;符指针的数组)识别无符号整数是将数字串转换为无符号整数。我们在getchar()的时候是把数字当做字符从外部输出读取的。将数字串345#转换为整数:(3*10+4)*10+5=345 送到 sum 中程序主要由2个函数组成,主函数main()和扫描子函数scanner。扫描程序每次读取 1个独立意义的单词符号,并判断单词类型。主程序做相应处理后做控制台输出。流程框图调用扫描子理序

4、输出电荷二亓织*图1主程序图2扫描子程序算法设计词法分析程序所用的较为重要的全局变量和需调用的函数如下:1) Ch字符变量,存放当前读进的源程序字符。2) token8字符数组,存放构成单词符号的字符串。3) prog80字符数组,存放 所有用户输入的字符。4) syn整数,存放当前单词的种别码。5) sum双精度浮点型变量,存放无符号整数,或者浮点数。6) isDecimal整数,是否为浮点数。isDecimal为1,则为浮点数。7) decimal双精度浮点型变量(double),浮点数的小数部分。8) isExp整数,是否为指数形式表示的浮点数(即是否存在符号E或者e)。isExp为1,

5、则为指数形式。9) index整数,指数形式的幕。10) isNegative 整数,是否为负数幕。isNegative 为1,则为负数幕,女口 123E-2。11) scanner。扫描子程序。12) getchar()从控制台读取一个字符数据。13) double pow(double x,double y) ,计算 x 的 y 次幕。14) int strcmp(char *str1,char #str2),字符串比较。函数相关说明1. 接收用户输入:getchar()和dowhile循环的组合doch=getchar();progp+=ch;while(ch!=#); /输入以#号键结

6、束2. 输出到控制台:dowhile循环中,扫描出单词后(扫描程序还会判断种别码syn)输出。doscann er(); / 扫描,单词switch(s yn)case 11:if(isDecimal=O)prin tf(”(2d,%8d)n,sy n,(i nt)sum);break;else if(isExp=1)prin tf(%2d,%10.5e)n,sy n,sum);isExp=0;isDecimal=0;break;else if(isDecimal=1)prin tf(%2d,%8.4f)n,sy n, sum);isDecimal=0;break;case -1:prin t

7、f(i nput errorn ”);break;default:prin tf(%2d,%8s)n,sy n,toke n);while(s yn !=0);3. 浮点数的识别,先识别数字,再识别.,再识别数字,再识别E或e,再识别-,再识别数字。elseif(ch=0)&(ch=0)&( ch=0)&(ch=0)&(ch=9)/指数in dex=i ndex*10+ch-0;ch=progp+;if(isNegative)sum=sum*pow(0.1,i ndex);elsesum=sum*pow(10,i ndex);p-;syn=11;输入与输出词法分析程序需具备词法分析的功能:输入

8、:所给文法的源程序字符串。(字符串以“ #”号结束)输出:二元组(syn,token 或sum)构成的序列。其中:syn为单词种别码;toke n为存放的单词自身字符串;sum为整型常数。程序运行结果*F:re9 then x;=2*x+l/3; end#k iFbegins11, 2,23. 11.竄10, x/26,; 0.fl)Pressany key to continue*C:UersEr n-Debugtest.exePlease input string:322123 +-1234 _56e123 +1 +-2lt.23456e-120C13,+Pressany key to c

9、ont inue五、实验方案设计实现用C语言实现。六、实验程序亮点描述浮点数处理部分:巧妙利用double pow(double x,double y)函数,简化了浮点数处理部分。如果是简单浮点数,如1.23,出现“.”符号,置isDeminal为1,用%f输出。如果稍微复杂一点,指数形式,但是正数幕,如1.23E2,出现“ E”符号,置isExp为1,用。输出。如果更复杂一点,指数形式,但是负数幕,如1.23E-2,出现“-”号,置isNegative为1,仍然用e输出。如果是有符号数(有符号整数或者有符号浮点数),在识别出“ +”或者“-”之后,再读后边一个字符,如果是数字,那么转至识别数

10、字的代码段, 并在末尾将sum进行相应处理。 如果后边字符不是数字,证明“ +”或者“-”是加减号,而非正负号。七、实验程序使用说明用户输入待识别字符串(并以“ #”结尾,表示字符串输入结束),回车后程序自动输出 词法分析结果。八、实验心得体会词法分析的基本任务是从字符串表示的源程序中识别出具有独立意义的单词符号,其基本思想是根据扫描到单词符号的第一个字符的种类,拼出相应的单词符号。 通过本试验的完成,更加加深了对词法分析原理的理解。最初是按照老师课堂上的 C语言实现这个思路进行的, 但是后来老师要求将识别数字拓 展到浮点数(即实数)。由于本人C语言功底不够扎实,最后只得再回过头去看了一下C语

11、言的语法,不过最后还是通过自己的力量把东西给做出来了。很有成就感!九、源程序清单#in clude#in clude#in cludechar prog80; II存放所有输入字符char toke n8; II存放词组实用文档char ch; / 单个字符int syn,p,m,n; syn:种另 U编码double sum;int count;int isSignal; / 是否带正负号(0不带,1负号,2正号)int isDecimal; / 是否是小数double decimal; / 小数int isExp; /是否是指数int in dex; /指数幕int isNegative; /是否带负号double temp;int temp2;void sca nn er();char *rwtab 6=begi n,if,the n,while,do,e nd;void mai n()p=0;coun t=0;isDecimal=O;in dex=0;prin tf(n P

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 学术论文 > 其它学术论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号