1、 for(l=0;num!=0;l+) m=num%10; /sdfafda for(t=0;t!=l;t+) m=m*2; /dafdaf n=nm; num=num/10; /*dafdas2323*/ /the result is %d /,n); return 0 ;窗口运行结果:= *词法分析系统*请输入需要分析的文件名称:code.txt-处理完毕。共出现1个错误。共有21行,33个单词,236个字符。结果请在token_table.txt中查看。请按任意键继续. . .Token.txt;单词 记号# #include id relop,GTmain id( () ) int i
2、ntnum id, ,n id= relop,EQ0 numm idl idt id; ;printf idscanf id& &for for!= RELOP,UE+ +% %10 num* *2 numnm id/ / return returnError.txt:1.在第1行第15列出现非法字符Note.txt:line6.双引号间字符:line7.双引号间字符:%dline7.ddsfsdfline10.ssdfafdaline12.ddafdafline14.dafdas2323line17.双引号间字符:/the result is %d /Count.txt:四源代码头文件:st
3、ringcstdiocstdlibcstringfstreamiostreamusing namespace std;全局变量:const int MAXBUFFER=62; /缓冲区容量 const int LB=30; /左缓冲区大小 const int LRB=61; /左+右缓冲区大小const int KEY=32; /关键字个数 fstream code_file;int cnum;/列数 int lb_end,rb_end,forward; /左右缓冲区结束位置,向前指针 int lready,rready; /标记左右缓冲区是否已经录入过内容 char bufferMAXBUF
4、FER; /缓冲区 char C; /当前读入的字符 string token;/存放单词的字符串 int keynum,errornum; /关键字的序列号 ; error的个数 int lnum,wordnum,charnum;/语句数 单词数 字符数 char *keyKEY=auto,constdoublefloatintshortstruct ,unsignedbreakcontinueelseforlongsignedswitchvoidcasedefaultenumgotoregisterstatictypedefvolatilechardoexternifreturnsizeo
5、funionwhile; /关键字表 函数:void fillbuf(int x) if(x=0) /填充左半区 if(lready=0) /左半区未填充 code_file.read(buffer,LB); /读入LB个字符到buffer左半区中 if(code_file.gcount()!=lb_end) /如果读入的字符不足LB个在之后添加EOF buffercode_file.gcount()=EOF; else lready=0; else /填充右半区 if(rready=0) code_file.read(buffer+LB+1,LB); /读入LB个字符到buffer右半区中=
6、LB) buffercode_file.gcount()+LB+1=EOF; rready=0; void get_nbc();void get_char() C=bufferforward; /获取当前字符 if(C=EOF) return; else if(C=n) cnum=0; /列=0 lnum+; /+1行 else if(C=33 & C=126) charnum+; /字母或数字或符号的话+1字符 /cout第charnum字符-Cendl; cnum+; forward+; if(bufferforward=EOF) if(forward=lb_end) /到左区结束位置 填
7、充右半区 fillbuf(1); if(forward=rb_end) /到右区结束位置 填充左半区 向前指针回到开始位置 fillbuf(0); forward=0;void retract()/向前指针后退一个字符 charnum-; cnum-; if(forward=0) lready=1; /避免重新读取 forward=rb_end-1; /后退一个字符 else if(forward=lb_end) rready=1; forward-; else forward-;void get_nbc() /若C中的字符为空字符则反复调用直到非空字符为止 while(C= | C=t0 |
8、 C=) get_char(); retract();int reserve(string word)/查关键字表 返回0表示token中的字符串是标识符 1表示关键字 for(keynum=0;keynumKEY;keynum+) if(pare(keykeynum)=0) return 1; return 0;主函数:main() cout=cout *词法分析系统* =endls; code_file.open(s); int p; while(code_file=NULL)无此文件,打开失败。请重新输入: /初始化 lb_end=LB; rb_end=LRB; lready=rread
9、y=0; lnum=1; wordnum=charnum=0; bufferlb_end=bufferrb_end=EOF; errornum=0;- fstream token_table,error,count,note; error.open(error.txt,ios_base:out); /保存错误 count.open(count.txt /保存语句数单词数字符数计数 note.open(note.txt /保存注释 token_table.open(token.txt/输出的记号 token_table64 &91) | (C96 &123) | C=_) /标示符判断 字母或者
10、下划线开头 token=token+C; while(C123) |(C47 &58) | C= /字母或数字或下划线 if(C!= C! &) wordnum+; /这是一个单词 if(reserve(token)=0)/这是一个标识符 tokentt id else /这是一个关键字 tt notelinelnum58) if(C=. if(C /小数点后必须有数字 否则报错Ee+- /E后面可以是+-号 /+-后面必须有数字否则报错 /后退一位后退出 else errornum+; errorerrornum.在第行cnum列出现错误 /E后面也可以是数字 其他情况则报错 else /退出 else/记录错误 退出此if重新判断 列出现错误)/E后面可以是+-号 58)/+-后面必须有数字否则报错 tt num switch(C) case /或者=或者或者= =tt relop,GEtt relop,GT /=tt relop,EQ /:=或者:tt : /!=tt RELOP,UEtt !/ /过滤注释) /过滤掉/开头的注释.C; et_char();*) /过滤掉/*开头的注释 while(1)*/tt / case#()%,tt default:列出现非法字符
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1