欢迎来到天天文库
浏览记录
ID:30419016
大小:19.44 KB
页数:12页
时间:2018-12-29
《编译原理报告》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、为了适应公司新战略的发展,保障停车场安保新项目的正常、顺利开展,特制定安保从业人员的业务技能及个人素质的培训计划编译原理报告 南京航空航天大学 编译原理课程设计 题目一个PASCAL语言子集编译器的设计与实现 专业 班号 学号 姓名 指导老师 答辩日期XX年1月 1设计的题目 一个PASCAL语言子集编译器的设计与实现2课程设计的要求 PL/0语言可以看成PASCAL语言的子集,它的编译程序是一个编译解释执行系统。PL/0的目标程序为假想栈式计算机的汇编语言,与具体计算机无关。 PL
2、/0的编译程序和目标程序的解释执行程序都是用C语言书写的,因此PL/0语言可在配备C语言编译器的任何机器上实现。目的-通过该培训员工可对保安行业有初步了解,并感受到安保行业的发展的巨大潜力,可提升其的专业水平,并确保其在这个行业的安全感。为了适应公司新战略的发展,保障停车场安保新项目的正常、顺利开展,特制定安保从业人员的业务技能及个人素质的培训计划 其编译过程采用一趟扫描方式,以语法分析程序为核心,词法分析和代码生成程序都作为一个独立的过程,当语法分析需要读单词时就调用词法分析程序,而当语法分析正确需要生成
3、相应的目标代码时,则调用代码生成程序。 用表格管理程序建立变量、常量和过程标示符的说明与引用之间的信息联系。 用出错处理程序对词法和语法分析遇到的错误给出在源程序中出错的位置和错位性质。 当源程序编译正确时,PL/0编译程序自动调用解释执行程序,对目标代码进行解释执行,并按用户程序的要求输入数据和输出运行结果。 3设计任务: PL/0语言文法的EBNF表示〈表达式〉::=[+
4、-]〈项〉{〈加法运算符〉〈项〉}〈项〉::=〈因子〉{〈乘法运算符〉〈因子〉} 〈因子〉::=〈标识符〉
5、〈无符号整数〉
6、
7、‘’〈加法运算符〉::=+
8、- 〈乘法运算符〉::=*
9、/ 〈关系运算符〉::==
10、#
11、
12、>= 〈条件语句〉::=IF〈条件〉THEN〈语句〉 〈过程调用语句〉::=CALL〈标识符〉 〈当型循环语句〉::=WHILE〈条件〉DO〈语句〉 〈读语句〉::=READ‘’〈写语句〉::=WRITE‘’〈字母〉::=a
13、b
14、…
15、X
16、Y
17、Z目的-通过该培训员工可对保安行业有初步了解,并感受到安保行业的发展的巨大潜力,可提升其的专业水平,并确保其在这个行业的安全感。为了适应公司新战略的发展,保障停车场安保
18、新项目的正常、顺利开展,特制定安保从业人员的业务技能及个人素质的培训计划 〈数字〉::=0
19、1
20、…
21、8
22、9 PL/0语言可以看成PASCAL语言的子集,它的编译程序是一个编译解释执行系统。PL/0的目标程序为假想栈式计算机的汇编语言,与具体计算机无关。 PL/0的编译程序和目标程序的解释执行程序都是用PASCAL语言书写的,因此PL/0语言可在配备PASCAL语言的任何机器上实现。 其编译过程采用一趟扫描方式,以语法分析程序为核心,词法分析和代码生成程序都作为一个独立的过程,当语法分析需要读单词时就调
23、用词法分析程序,而当语法分析正确需要生成相应的目标代码时,则调用代码生成程序。 用表格管理程序建立变量、常量和过程表示符的说明与引用之间的信息联系。 用出错处理程序对词法和语法分析遇到的错误给出在源程序中出错的位置和错位性质。 当源程序编译正确时,PL/0编译程序自动调用解释执行程序,对目标代码进行解释执行,并按用户程序的要求输入数据和输出运行结果。 4原理与框图 (1).PL/0编译程序功能的框图目的-通过该培训员工可对保安行业有初步了解,并感受到安保行业的发展的巨大潜力,可提升其的专业水平,并确
24、保其在这个行业的安全感。为了适应公司新战略的发展,保障停车场安保新项目的正常、顺利开展,特制定安保从业人员的业务技能及个人素质的培训计划 PL/0的编译程序包括了对PL/0语言源程序进行分析处理、编译生成类PCODE代码,并在虚拟机上解释运行生成的类PCODE代码的功能。 输入输出 .PL/0编译程序的总体设计 PL/0语言编译程序采用以语法分析为核心、一遍扫描的编译方法。词法分析和代码生成作为独立的子程序供语法分析程序调用。当语法 分析需要读单词时就调用词法分析程序,而当语法、语义分析正确,需要生
25、成相应的目标代码时,则调用代码生成程序。语法分析的同时,提供了出错报告和出错恢复的功能。在源程序没有错误编译通过的情况下,调用类PCODE解释程序解释执行生成的类PCODE代码 词法分析子程序分析: 词法分析子程序名为getsym,功能是从源程序中读出一个单词符号,把它的信息放入全局变量sym、id和num中,语法分析器需要单词时,直接从这三个变量中获得。getsym过程通过反复调用getch子
此文档下载收益归作者所有