设计思想 (1)程序主体结构部分: 说明部分 %% 规则部分 %% 辅助程序部分 (2)主体结构的说明 在这里说明部分告诉我们使用的LETTER,DIGIT, IDENT(标识符,通常定义为字母开头的字母数字串)和STR(字符串常量,通常定义为双引号括起来的一串字符)是什么意思.这部分也可以包含一些初始化代码.例如用#include来使用标准的头文件和前向说明(forward ,references).这些代码应该再标记"%{"和"%}"之间;规则部分>可以包括任何你想用来分析的代码;我们这里包括了忽略所有注释中字符的功能,传送ID名称和字符串常量内容到主调函数和main函数的功能. (3)实现原理 程序中先判断这个句语句中每个单元为关键字、常数、运算符、界符,对与不同的单词符号给出不同编码形式的编码,用以区分之。 PL/0语言的EBNF表示 ::==; ::=={|}; ::=+|- ::=*|/ ::==|#|<||>= ::=a|b|…|X|Y|Z ::=0|1|2|…|8|9 三:设计过程 1. 关键字:void,main,if,then,break,int,Char,float,include,for,while,printfscanf 并为小写。 2."+”;”-”;”*”;”/”;”:=“;”:”;”<“;”“;”>=“;”“;”=“;”(“;”)”;”;”;”#”为运算符。 3. 其他标记 如字符串,表示以字母开头的标识符。 4. 空格符跳过。 5. 各符号对应种别码 关键字分别对应1-13 运算符分别对应401-418,501-513。 字符串对应100 常量对应200 结束符# 四:举例说明 目标:实现对常量的判别 代码: digit [0-9] letter [A-Za-z] other_char [!-@\[-~] id ({letter}|[_])({letter}|{digit}|[_])* string {({letter}|{digit}|{other_char})+} int_num {digit}+ %% [ |\t|\n]+ "auto"|"double"|"int"|"struct"|"break"|"else"|"long"|"switch"|"case"|"enum"|"register"|"typedef"|"char"|"extern"|"return"|"union"|"const"|"float"|"short"|"unsigned"|"continue"|"for"|"signed"|"void"|"default"|"goto"|"sizeof"|"do"|"if"|"static"|"while"|"main" {Upper(yytext,yyleng);printf("%s,NULL\n",yytext);} \"([!-~])*\" {printf("CONST_string,%s\n",yytext);} -?{int_num}[.]{int_num}?([E][+|-]?{int_num})? {printf("CONST_real,%s\n",yytext);} "0x"?{int_num} {printf("CONST_int,%s\n",yytext);} ","|";"|"("|")"|"{"|"}"|"["|"]"|"->"|"."|"!"|"~"|"++"|"--"|"*"|"&"|"sizeof"|"/"|"%"|"+"|"-"|">"|"="|">="|"<<="|"&="|"^="|"|="|"=" {printf("%s,NULL\n",yytext);} {id} {printf("ID,%s\n",yytext);} {digit}({letter})+ {printf("error1:%s\n",yytext);} %% #include Upper(char *s,int l) { int i; for(i=0;i
2019-12-21 18:52:27 105KB 词法分析器制作
1
非常基础的词法分析器,能够将各个单词分开,判断各个单词的类型,并输出相应的tokens和符号表。还存在一些BUG,希望大家不吝赐教。
2019-12-21 18:51:05 257KB 词法 分析器 token 符号表
1
编译原理实验源代码,包括赋值语句的词法分析和语法分析。语法分析是利用的算符优先法
1
我的编译原理课程设计,请大家多多指教!!!
2019-12-21 18:49:34 35KB PL0 词法 语法
1
内容: 一共有实验一和实验二两个实验,每个实验有4次课8个学时; 实验一完成词法分析; 实验二完成语法、语义分析及中间代码生成。 两个实验完成后最终效果: 实现一个简单的集成开发环境(IDE),可以编辑源代码、有“编译”、“运行”等功能; 需要显示所有的错误信息、扫描结果、语法分析结果、中间代码和汇编代码 (做实验一时可以使用命令行界面)
2019-12-21 18:49:28 2.6MB 华工 编译原理 实验
1
利用C#实现的词法语法分析器,能解析运算表达式,有极强的参考价值
1
java编写的词法分析器模拟自动机的运行,但是此程序只是初级版本未实现报错功能,提供一种思想。附测试用例
2019-12-21 18:48:22 3KB java,词法分析,自动机
1
C#实现的词法分析器,VS2010版本,比较简单,很容易懂
2019-12-21 18:48:07 60KB C#词法分析器
1
能够根据单词的构词规则,完成MiniC语言中的单词的解析(词法分析),如果不符合单词的构词规则,请给出错误信息。如果源语言符合单词的词法规则,请输出二元式。 (注:利用JavaCC实现) 在词法分析的基础上,构造MiniC的LL(1)文法,利用JavaCC实现LL(1)文法,判断源语言是否符合MiniC的语法,如果不符合,请给出语法错误信息。 在语法分析的基础上,根据属性文法制导翻译,进行语义分析,输出四元式。如果源语言不符合MiniC的语义,请指出错误信息。 在平时实习课的基础上,整个编译系统要能够翻译数组(二维)翻译,if..else, for, while,赋值等语句嵌套的分析与翻译 1.整个编译系统利用JavaCC来实现. 2.用流的形式读入要分析的MiniC源程序。 3.语法分析,利用.jjt文件,这样语法分析,可以生成树的层次结构。 4.单词序列、树状的层次结构图、四元式的结果,输出到文件中。
1
详细介绍了词法分析器自动生成器Flex和语法分析器自动生成器Bison的的原理,使用
2019-10-21 09:14:38 14.74MB flex bison 词法分析 语法分析
1