编译原理报告

编译原理报告

ID:30419016

大小:19.44 KB

页数:12页

时间:2018-12-29

编译原理报告_第1页
编译原理报告_第2页
编译原理报告_第3页
编译原理报告_第4页
编译原理报告_第5页
资源描述:

《编译原理报告》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

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子

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。