




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、编译原理词法分析程序设计实验报 【实验目的】 1了解词法分析的主要任务。 2熟悉编译程序的编制。 【实验内容】 根据某文法,构造一基本词法分析程序。找出该语言的关键字、标识符、整数 以及其他一些特殊符号,给出单词的种类和值。 【实验要求】 3构造一个小语言的文法 类 C 小语言文法(以 EBNF 表示) 程序:=分程序 分程序 . 分程序 : =标识符 ( 变量说明部分 ,变量说明部分 )函数体 变量说明部分:=int标识符,标识符 函数体 : : = 变量说明部分 。语句序列 语句序列 : : =语句序列 。语句|语句 语句:=赋值语句 |条件语句 |循环语句 |函数调用语句 赋值语句 :=
2、标识符 =表达式 表达式 : : =+|- 项加法运算符 项 项:=因子乘法运算符 因子 因子:=标识符|无符号整数 加法运算符 := +|- 乘法运算符 := *|/ 条件语句:=if条件语句序列 else语句序列 条件:=表达式 关系运算符 表达式 关系运算符 := =|!=|=|= 循环语句:=for 表达式 。条件 。表达式 )语句序列 函数调用语句 :=标识符 (标识符 ,标识符 |空) 标识符 :=字母字母|数字 : = :=a|b|c|X|Y|Z :=0|1|2|8|9 单词分类情况 关键字: int if else for 标识符:以字母开头的字母和数字的组合 关系运算符: =
3、|!=|=|= 加法运算符: +|- 乘法运算符: *|/界符:,; ( ) 4 设计单词的输出形式,单词的种类和值的表示方法 种别码 单词值 如: 1 int 3. 编写词法分析程序 cffx.c 实现基本的词法分析器,能够分析关键字、标识符、数字、运算符(需要有“ =”或 =”之类需要超前搜索的运算符)以及其他一些符号。 / 编译原理词法分析程序 .cpp #include #include #include typedef struct words int id 。 char name20 。 char value20 。 word 。 char integer20=i,n,t 。 ch
4、ar iff20=i,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 类别:关键字 elsen) 。 printf( 种别码: 4 类别:关键字 forn) 。 printf( 种别码: 5 类别:标识符 n) 。
5、printf( 种别码: 6 类别:计算运算符 n) 。 printf( 种别码: 7 类别:关系运算符 n) 。 printf( 种别码: 8 类别:界符 n) 。 while(1) gets(code)。 n=strlen(code) 。 for(m=0,j=0。m=a&codem=0&codem=9) wordsj=codem 。 j+。 else if(words0=i&words1=n&words2=t&words3=0) symbolk.id=1 。 for(i=0。 i20。 i+) symbolk.valuei=wordsi 。 k+。 else if(words0=i&wor
6、ds1=f&words2=0) symbolk.id=2 。 for(i=0。 i20。 i+) symbolk.valuei=iffi 。 k+。 else if(words0=e&words1=l&words2=s&words3=e&words4=0) symbolk.id=3 。 for(i=0 。 i20。 i+) symbolk.valuei=elseei 。 k+。 else if(words0=f&words1=o&words2=r&words3=0) symbolk.id=4 。 for(i=0 。 i20。 i+) symbolk.valuei=forri 。 k+。 els
7、e symbolk.id=5 。 for(i=0 。 i20。 i+) symbolk.valuei=wordsi 。 k+。 for(p=0。p20。p+) wordsp=0 。 j=0。 if(codem=+) symbolk.id=6 。 symbolk.value0=+ 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=-) symbolk.id=6 。 symbolk.value0=- 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=*) symbolk.id=6 。 s
8、ymbolk.value0=* 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=/) symbolk.id=6 。 symbolk.value0=/ 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=&codem+1!=) symbolk.id=6 。 symbolk.value0= 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=&codem+1=) symbolk.id=7 。 symbolk.value0= 。 sym
9、bolk.value1= 。 for(i=2 。 i20。 i+) symbolk.valuei=0 。 k+。 m+。 if(codem=!&codem+1=) symbolk.id=7 。 symbolk.value0=! 。 symbolk.value1= 。 for(i=2 。 i&codem+1=) symbolk.id=7 。 symbolk.value0= 。 symbolk.value1= 。 for(i=2 。 i20。 i+) symbolk.valuei=0 。 k+。 m+。 if(codem=&codem+1=) symbolk.id=7 。 symbolk.valu
10、e0= 。 symbolk.value1= 。 for(i=2 。 i) symbolk.id=7 。 symbolk.value0= 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=) symbolk.id=7 。 symbolk.value0= 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=,) symbolk.id=8 。 symbolk.value0=, 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem= 。 )
11、symbolk.id=8 。 symbolk.value0= 。 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=() symbolk.id=8 。 symbolk.value0=( 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=) symbolk.id=8 。 symbolk.value0=) 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=) symbolk.id=8 。 symbolk.value0= 。 for(
12、i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 if(codem=) symbolk.id=8 。 symbolk.value0= 。 for(i=1 。 i20。 i+) symbolk.valuei=0 。 k+。 count=k 。 system(cls)。 for(i=0 。 icount 。 i+) printf(%d ,symboli.id) 。 printf(%sn,symboli.value) 。 1 return 0 。 4.生成并输出单词符号表 1 】00 00 5 OB 5 5 00 识别单词的状态转换图: 5流程图 结束 6源程序清单 int a,b,c。 a=b+c。 7测试结果 C:UsersTHI NKDeskQpU ntitled l.ece C AUsersXTHI 忖 KDe3ktopUntitled l.exe C ! a = b + 8.实验心得: 此次实验让我了解了如何设计、编制并调试词法分析程
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年乡村医生考试:农村居民健康档案管理政策宣传试题集
- 2025年工程测量员(地质工程测量技师)考试试卷
- 2025年电气石项目提案报告
- 2025年门诊医疗服务项目规划申请报告
- 2025年明胶空心胶囊项目立项申请报告
- 2025年走芯车床项目立项申请报告
- 2025年电梯安装改造维修作业特种作业操作证考试试卷(电梯机械知识应用案例分析)
- 详细资金流动记录出资证明书(8篇)
- 教育行业教育行业教育行业教育游戏市场2025年发展趋势与商业模式研究报告
- 2025年农业面源污染治理农村环境治理技术应用案例报告
- GB 29837-2013火灾探测报警产品的维修保养与报废
- 一例慢阻肺病人护理个案
- 建平中学自招真题解析
- DB50-T 1293-2022 松材线虫病疫木除治技术规范(标准文本)
- 微电子工艺实验报告
- 金属材料检验的标准课件
- 动物疫病流行病学调查表诊断送检用
- 模具技术要求
- 广东省公务员录用审批表
- 士兵提干考军校(适用全国各地)2025年考试试题
- 钻孔灌注桩灌注旁站记录
评论
0/150
提交评论