1、returnvoidwhile共6个,所有的关键字都是保留字,并且必须是小写;标识符:识别与C语言词法规定相一致的标识符,通过下列正则表达式定义:ID=letter(letter|digit)*;常数:NUMdigitdigit*(.digitdigit*|)(e(+-|)|),lettera|.|z|A|.|Z|,digit0|.|9,包括整数,如123等;小数,如123.45等;科学计数法表示的常数,如1.23e3,2.3e-9等;专用符号:+*/=!,()/*/;2、分析器的输入为由上述几类单词构成的程序,输出为该段程序的机内表示形式,即关键字、运算符、界限符变为其对应的机内符,常数使用
2、二进制形式,标识符使用相应的标识符表指针表示。3、词法分析器应当能够指出源程序中的词法错误,如不可识别的符号、错误的词法等。四、实验结果(程序)及分析#includestdlib.hstring.h#defineN100typedefstruct charname30; intcode;addr;token;/存储刚从文件中读取的字符charKeyword;symbol;Keywordkey6=else,1,if,2,int,3,return,4,void,5,where,6;ch;/接受字符FILE*source;/源文件*keytxt;/关键字输出文件*badgetxt;/标识符输出文件*
3、othertxt;/其他单词输出文件*number;error_count;/错误的个数addr_count;/标识符表的指针lineof;/行号tokencurrent;/暂时存放读入的字符zancun;symbolcurrentsymbol;symboltableN;/标识符表error(inti);main()scan();error_count=0;addr_count=0;lineof=0;scan()i=0;iskeyword();/判断关键字isOthers()/判断其他单词output_1();output_2();output_others();/其他单词输出文件Iszhus
4、hi();isnumber();if(source=fopen(Source.txt,r)=NULL)/打开源文件printf(fileopenerror/n);exit(0);if(keytxt=fopen(key.txtw/打开关键字文件if(badgetxt=fopen(badge.txt/打开标识符文件if(othertxt=fopen(others.txt)=NULL)errorn if(number=fopen(number.txt ch=fgetc(source); while(ch!=EOF) for(i=0;i=a&chAZ|ch=_)if(ch=if(ch09elseisO
5、thers();fclose(source); fclose(keytxt);fclose(badgetxt);fclose(othertxt); fclose(number);iskeyword()i=0,k=0,j=0;h=0;while(ch(ch(chcurrent.namei=ch;i+;ch=fgetc(source);zancun=current;for(i=0;6;i+)for(j=0;jcurrent.namek+=ch;current.code=11;output_1()关键字:%s,%d,current.name,current.code);putchar(10);fprintf(keytxt,output_2() printf(标识符地址:,current.name,addr_count); putchar(10);fprintf(badgetxt,output_others()其它单词:fprintf(othertxt,i)switch(i)1:界符发生错误,发生在第%d行/n,lineof);2:注释发生错误,发生在第%d行/noutput_number()常数nfprintf(number,实验结果分析,程序运行结果截图:关键字输出文件:标识符输出文件:数字的输出文件其它单词输出文件:
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1