下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 编译原理词法分析程序设计实验报告【实验目的】1 了解词法分析的主要任务。2 熟悉编译程序的编制。【实验容】根据某文法,构造一基本词法分析程序。找出该语言的关键字、标识符、整数以及其他一些特殊符号,给出单词的种类和值。【实验要求】1. 构造一个小语言的文法类C小语言文法(以EBNF表示)<程序>:=<分程序><分程序> . <分程序>:=<标识符>(<变量说明部分>,<变量说明部分>)<函数体> <变量说明部分>:=int<标识符>,<标识符> <函数体&g
2、t;:=<变量说明部分><语句序列> <语句序列>:=<语句序列><语句>|<语句> <语句>:=<赋值语句>|<条件语句>|<循环语句>|<函数调用语句> <赋值语句>:=<标识符>=<表达式> <表达式>:=+|-<项><加法运算符><项> <项>:=<因子><乘法运算符><因子> <因子>:=<标识符>|
3、<无符号整数> <加法运算符>:= +|- <乘法运算符>:= *|/ <条件语句>:=if<条件><语句序列>else<语句序列> <条件>:=<表达式><关系运算符><表达式> <关系运算符>:= =|!=|>|<|>=|<= <循环语句>:=for(<表达式><条件><表达式>) <语句序列> <函数调用语句>:=<标识符>(<标识符
4、>,<标识符>|<空>) <标识符>:=<字母><字母>|<数字> <无符号整数>:=<数字><数字> <字母>:=a|b|c|X|Y|Z <数字>:=0|1|2|8|9单词分类情况关键字:int if else for标识符:以字母开头的字母和数字的组合关系运算符: =|!=|>|<|>=|<=加法运算符:+|- 乘法运算符: *|/界符:,; ( )2. 设计单词的输出形式,单词的种类和值的表示方法种别码 单词值如:1 int3.
5、 编写词法分析程序cffx.c实现基本的词法分析器,能够分析关键字、标识符、数字、运算符(需要有“=”或“:=”之类需要超前搜索的运算符)以及其他一些符号。/ 编译原理词法分析程序.cpp #include<stdio.h>#include<stdlib.h>#include<string.h>typedef struct wordsint id;char name20;char value20;word;char integer20='i','n','t'char iff20='i','
6、;f'char elsee20='e','l','s','e'char forr20='f','o','r'int main()char code10000;char words20,ch;int i,j,p,count,n,m;int k=0;word symbol500; printf("种别码:1 类别:关键字intn"); printf("种别码:2 类别:关键字ifn"); printf("种别码:3 类别:关键字e
7、lsen"); printf("种别码:4 类别:关键字forn"); printf("种别码:5 类别:标识符n"); printf("种别码:6 类别:计算运算符n"); printf("种别码:7 类别:关系运算符n"); printf("种别码:8 类别:界符n");while(1)gets(code);n=strlen(code);for(m=0,j=0;m<n;m+) if(codem>='a'&&codem<='z
8、')|(codem>='0'&&codem<='9') wordsj=codem;j+; else if(words0='i'&&words1='n'&&words2='t'&&words3='0') symbolk.id=1; for(i=0;i<20;i+) symbolk.valuei=wordsi; k+; else if(words0='i'&&words1='
9、f'&&words2='0') symbolk.id=2; for(i=0;i<20;i+) symbolk.valuei=iffi; k+; else if(words0='e'&&words1='l'&&words2='s'&&words3='e'&&words4='0') symbolk.id=3; for(i=0;i<20;i+) symbolk.valuei=elseei; k+; else
10、 if(words0='f'&&words1='o'&&words2='r'&&words3='0') symbolk.id=4; for(i=0;i<20;i+) symbolk.valuei=forri; k+; else symbolk.id=5; for(i=0;i<20;i+) symbolk.valuei=wordsi; k+; for(p=0;p<20;p+) wordsp=0; j=0; if(codem='+') symbolk.i
11、d=6; symbolk.value0='+' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem='-') symbolk.id=6; symbolk.value0='-' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem='*') symbolk.id=6; symbolk.value0='*' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem='/&
12、#39;) symbolk.id=6; symbolk.value0='/' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem='='&&codem+1!='=') symbolk.id=6; symbolk.value0='=' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem='='&&codem+1='=') symbolk.id=7; symbolk.val
13、ue0='=' symbolk.value1='=' for(i=2;i<20;i+) symbolk.valuei=0; k+; m+; if(codem='!'&&codem+1='=') symbolk.id=7; symbolk.value0='!' symbolk.value1='=' for(i=2;i<20;i+) symbolk.valuei=0; k+; m+; if(codem='>'&&codem+1='
14、=') symbolk.id=7; symbolk.value0='>' symbolk.value1='=' for(i=2;i<20;i+) symbolk.valuei=0; k+; m+; if(codem='<'&&codem+1='=') symbolk.id=7; symbolk.value0='<' symbolk.value1='=' for(i=2;i<20;i+) symbolk.valuei=0; k+; m+; if(c
15、odem='>') symbolk.id=7; symbolk.value0='>' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem='<') symbolk.id=7; symbolk.value0='<' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem=',') symbolk.id=8; symbolk.value0=',' for(i=1;i<20;i+)
16、 symbolk.valuei=0; k+; if(codem='') symbolk.id=8; symbolk.value0='' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem='(') symbolk.id=8; symbolk.value0='(' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem=')') symbolk.id=8; symbolk.value0=')' for(i=
17、1;i<20;i+) symbolk.valuei=0; k+; if(codem='') symbolk.id=8; symbolk.value0='' for(i=1;i<20;i+) symbolk.valuei=0; k+; if(codem='') symbolk.id=8; symbolk.value0='' for(i=1;i<20;i+) symbolk.valuei=0; k+; count=k; system("cls"); for(i=0;i<count;i+) printf("%d ",symboli.id); printf("%sn",symboli.value); return 0;4.生成并输出单词符号表识
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025河南周口城投发展集团有限公司招聘26人笔试考试备考试题及答案解析
- 2025云南保山市瑞积中学招聘3人考试笔试模拟试题及答案解析
- 岳池县2025年社会化选聘新兴领域党建工作专员考试笔试备考试题及答案解析
- 2025云南省凤庆糖业集团营盘有限责任公司招聘2人笔试考试备考题库及答案解析
- 2025湖南君山生态渔业集团有限公司下属子公司湘北水产良种场按劳务派遣制招聘专业技术人员笔试考试参考题库及答案解析
- 2025四川藏区高速公路招聘20人笔试考试备考题库及答案解析
- 2025年西安铁路职业技术学院高层次及紧缺人才招聘(14人)考试笔试模拟试题及答案解析
- 2025福建厦门市集美区杏苑小学非在编教师招聘1人考试笔试备考题库及答案解析
- 2026广西钦州市教育系统“钦聚英才”专场集中招聘急需紧缺人才和硕士研究生骨干教师172人笔试考试备考试题及答案解析
- 2026中国储备粮管理集团有限公司新疆分公司招聘31人笔试考试备考题库及答案解析
- 【初中生物】真菌(教学课件)-2025-2026学年人教版生物七年级上册
- 口腔放射知识培训记录课件
- 交通运输行业深度报告:无人机反制系统-奠定低空经济安全发展之基石
- 棉花仓库安全培训课件
- 2025年民航飞行员招飞心理测试题及答案
- 2025年广西国家工作人员学法用法考试试题及答案
- 古代绘画技法研究
- 智慧树知道网课《敦煌学》课后章节测试满分答案
- 人造地球卫星教学课件
- (2025秋新版)青岛版科学二年级上册全册教学设计
- 网络舆情应对管理办法
评论
0/150
提交评论