- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编号:
实习
一
二
三
四
五
六
七
八
九
十
总评
教师签名
成绩
《编译原理》课程
实习报告
编 号: 3
实习题目: 语法分析器
专业(班): 计科六班
学生学号: 2011301500204
学生姓名: 何子龙
任课教师: 杜卓敏
问题定义与分析
1.1 实习目的
构造一个小语言的语法分析程序。
1.2 实习要求
((1)输入属性字文件,输出源程序是否符合语法要求的结果:
正确——该程序符合语法要求。
错误——指出错误位置。
(2)运行实例:
例 1: 输入 i:=1+;
输出 表达式错误。
例2: 输入 program ex1;begin i:=1 end.
输出 该程序是正确的。
1.3 要求分析
1.3.1 输入部分
输入为文法源程序,定义CString 类型变量 m_EnterString ,用于获取编辑框1的输入,将其转换为char类型的数组,用s 保存,即char *s=m_EnterString.GetBuffer() 。
1.3.2 输出部分
对于错误的程序,输出相应错误类型;对于正确的程序,输出该程序是正确的。定义CString 类型变量m_OutputString ,用于输出词法分析结果到编辑框2,用如下函数给m_OutputString 添加输出内容,如程序正确时代码:m_OutputString.Insert(m_OutputString.GetLength(),该程序是正确的);
如图所示:
1.3.3 待分析的简单语言的语法
用扩充的BNF表示如下:
⑴程序::=program begin语句串end|begin语句串end
⑵语句串::=语句{;语句}
⑶语句::=赋值语句
⑷赋值语句::=ID:=表达式
⑸表达式::=项{+项 | -项}
⑹项::=因子{*因子 | /因子
⑺因子::=ID | NUM | (表达式)
1.3.4 语法中的各种单词符号对应的类别码
单词符号
类别码
单词符号
类别码
begin
1
18
end
2
=
19
if
3
20
then
4
21
else
5
22
while
6
=
23
program
7
24
int
8
(
25
char
9
)
26
标识符
10
{
27
常数
11
}
28
+
12
29
-
13
;
30
*
14
,
31
/
15
[
32
=
16
]
33
:=
17
#
0
program
34
其中对应于在词法分析程序中,变化的是将关键字do改为program,和begin两者至少出现一个作为程序的开始标志。
设计
2.1 数据结构
定义了以下字符串类型数据:
CString m_EnterString :用于接受编辑框1输入的源程序
CString m_OutputString; :用于保存输出到编辑框2的内容,即输出源程序是正确的还是错误的,对于错误的程序还需要说明错误类型
char *s=m_EnterString.GetBuffer() :用于将输入的Cstring类型转换为字符数组
类型
界面数据结构:(仅在词法分析程序的基础上改变了以下组件的位置与大小)
IDC_STATIC1 (Group-
文档评论(0)