编译原理词法分析程序C++.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编译原理词法分析程序C

编译原理 词法分析程序 C++ #include iostream #include fstream #include string using namespace std; /*全局变量*/ ifstream infile; //读取目标字符串 ofstream outfile; //向文件中输出结果 char buf1[64] ,buf2[64]; //双缓冲 char *p2; //指向双缓冲char数组的指针 char ci; //用来存储从文件中读取的单个char string token; //多个ci组成的一个字符串 string keyWord[]={asm,do,if,return,typedef,auto,double,inline,short,typeid, bool,dynamic_cast,int,signed,typename,break,else,long,sizeof, union,case,enum,mutable,static,unsigned,catch,explicit,namespace, static_cast,using,char,export,new,struct,virtual,class,extern,operator, switch,void,const,false,private,template,volatile,const_cast,float, protected,this,wchar_t,continue,for,public,throw,while,default,friend, register,true,delete,goto,reinterpret_cast,try,NULL};//保留字(摘自百度百科)最后一个NULL是我自己加的 const int KEYWORDLENGTH = 64; //keyWord[]的长度 /*全局变量*/ /*函数声明*/ void start(); //main函数开始时对程序的预处理 void get_ci(); //获取字符,使用双缓冲 bool isLetter(int); //判断是否是 字母 bool isDigit(int); //判断是否是 数字 bool isUnderLine(int); //判断是否是 下划线 bool isKeyWord(string); //判断是否是 关键字 char getType(char); //获取ci的类型 代表 void printFile(string ,string);//输出至文件 void retractPoint();//p2指针前移撤销一位 /*函数声明*/ void main() { start();//预处理,初始化 while (true)//死循环直到主动跳出 { token=;//每次循环时,清空 get_ci(); switch(getType(ci)) { case a://a是字母的代表,当ci是字母是,进入这个case { token=token+ci; get_ci(); while (isLetter(ci)||isDigit(ci)||isUnderLine(ci)) { token=token+ci; get_ci(); }//while循环跳出 if (isKeyWord(token)) { printFile(token,关键字); } else { printFile(token,标识符); }//此时指针指向了下一个 retractPoint();//所以指针要回退; } break; case _: { token=token+ci; get_ci(); while (isLetter(ci)||isDigit(ci)||isUnderLine(ci)) { token=token+ci; get_ci(); }//while循环跳出 if (isKeyWord(token)) { printFile(token,关键字); } else { printFile(token,标识符); }//此时指针指向了下一个

文档评论(0)

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

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

1亿VIP精品文档

相关文档