05号 曹琴 词法分析.docVIP

  1. 1、本文档共13页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
宁夏师范学院数学与计算机科学学院 《实验序号:    实验项目名称:学  号 姓 名 专业、班 实验地点 指导教师 时间 2013--4 实验目的1Visual C++6.0,VisualC++.NET and Visual C++.NET 2003 WinNT, Win 200, WinXP and Win2003 2 gcc version 3.3.2 (Red Hat Linux 3.3.2-1)Redhat Fedora core 1 Intel 32 platform 运行后输入PL/0 源程序文件名 回答是否输出虚拟机代码 回答是否输出名字表 fa.tmp 输出虚拟机代码 fa1.tmp 输出源文件及其各行对应的首地址 fa2.tmp 输出结果 fas.tmp 输出名字表 三、实验内容: PL的词法分析器将要完成以下工作: (1) 跳过分隔符(如空格,回车,制表符); while(ch== ||ch==10||ch==9) /* 忽略空格、换行和TAB */ { getchdo; } (2) 识别诸如begin,end,if,while等保留字; if(ch=ach=z) { /* 名字或保留字以a..z开头 */ k=0; do {if(kal){a[k]=ch;k++;}getchdo; } while(ch=ach=z||ch=0ch=9); a[k]=0; strcpy(id,a); i=0; j=norw-1; do /* 搜索当前符号是否为保留字 */ {k=(i+j)/2;if(strcmp(id,word[k])=0)j=k-1;if(strcmp(id,word[k])=0)i=k+1; }(3) 识别非保留字的一般标识符,此标识符值(字符序列)赋给全局量id,而全局量sym赋值为SYM_IDENTIFIER。 (4) 识别数字序列,当前值赋给全局量NUM,sym则置为SYM_NUMBER; (5) 识别:=,=,=之类的特殊符号,全局量sym则分别被赋值为SYM_BECOMES,SYM_LEQ,SYM_GEQ等。 赋值符号:if(ch==:) /* 检测赋值符号 */{getchdo;if(ch===){sym=becomes;getchdo;}else{sym=nul; /* 不能识别的符号 */}} 小于等于:if(ch==) /* 检测小于或小于等于符号 */{getchdo;if(ch===){sym=leq;getchdo;}else{sym=lss;}} 大于等于:{if(ch==) /* 检测大于或大于等于符号 */{getchdo;if(ch===){sym=geq;getchdo;}else{sym=gtr;}} 相关过程(函数)有getsym(),getch(),其中getch()为获取单个字符的过程,除此之外,它还完成: (1) 识别且跳过行结束符; (2) 将输入源文件复写到输出文件; (3) 产生一份程序列表,输出相应行号或指令计数器的值。 四、实验代码: /*词法分析,获取一个符号*/ int getsym() {int i,j,k; while( ch== ||ch==10||ch==9){ getchdo;} if(ch=ach=z) {k=0; do{if(kal){a[k]=ch;k++;}getchdo;}while(ch=ach=z||ch=0ch=9); a[k]=0; strcpy(id,a); i=0; j=norw-1; do{k=(i+j)/2;if(strcmp(id,word[k])=0){j=k-1;}if(strcmp(id,word[k])=0){i=k+1;} }while(i=j); if(i-1j) {sym=wsym[k]; } else {sym=ident; } } else { if(ch=0ch=9) {k=0;num=0;sym=number;do{num=10*num+ch-0;k++;getchdo;}while(ch=0ch=9); /*获取数字的值*/k--;if(knmax){error(30);} } else {if(ch==:)/*检测赋值符号*/{getchdo;if(ch===){sym=becomes;getchdo;}else{sym=nul;/*不能识别的符号*/}}else{if(ch==)/*检测小于或小于等于符号*/{getchdo;if(ch===){sym=leq;getchdo;}else{sym=ls

文档评论(0)

vtangojia + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档