- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE 2
面向类Pascal的静态编译语言设计
及语言的语法与指称语义分析设计
1. 语言设计的背景与范型
Python是一种解释型脚本语言,也是一种面向对象的动态类型语言,具有丰富的语法和类库。但是python的缺点有执行效率低,运行速度慢,很多情况下无法将程序连写成一行;并且动态语言由于没有构建的过程,因此很多错误只有等到运行时才会发现,代码检查工具的效率不高。
Pascal语言是最早出现的结构化编程语言,具有丰富的数据类型和简洁灵活的操作语句与控制结构,并且语法严谨,层次分明,程序易写,可读性强,编译运行效率高,查错能力强,有严格的结构化形式。
因此,本语言的设计目标是一种类Pascal静态类型的编译型语言,拥有高效的执行效率,又具有丰富的语言特性,并能够针对Python的部分缺点进行改进。所以本语言借鉴参考Python和C语言的众多优秀特性,同时以Pascal语言的静态编译特点为框架结构,设计出一个完备完整的,并且具有高效执行效率,严格词法语法错误反馈机制的结构化程序语言。
2. 语言设计思路与特点
设计目标:从底层到上层完整实现一门完备性良好的结构化的静态编译语言。
设计原则:严格的结构化形式,完备的数据类型,高效率的编写运行,严格的纠错机制。
设计思路:早期过程式语言调研,词法语法设计,指称语义设计与说明,词法分析,语法分析,纠错设计。
设计特色与优点:
(1)精简性:本语言作为一个轻量级静态编译语言,舍弃了不常用的词法和语法形式,使得用户在学习,编写,编译,查错过程中都能体会到简洁方便。
(2)完备性:虽然本语言较为精简,但是就词法来说,本语言几乎囊括了所有常用关键字,运算符和数据类型。就语法来说,本语言借鉴参考了Python、C、Pascal语言的语法结构,实现了从命令到程序的所有常见功能,完全满足轻量编程实践的需要。
(3)完整性:本语言完整实现了从语言设计到语法分析器的步骤,并且考虑到了用户体验,用户可直接从本语言的输出提示中获知编写的语言在编译层面的错误。
(4)词法语法错误反馈机制:借鉴了市场上绝大部分编译器的特点,本语言通过语法树可以给用户指出在哪一行,哪一部分代码可能发生了哪一类型错误。
3. 语言词法设计与EBNF
3.1 关键字
本语言有20个关键字,在此将其定义为keyWord类型,EBNF表达如下:
keyWord ::= begin | proc | while | var | func | is | do | array | in | record | if | let | then | of | type | end | else | const | try | catch
3.2 运算符
本语言有36种运算符,同样地,将其定义为Calculation类型,EBNF表达如下:
Calculation ::= + | - | * | / | , | ; | | = | | = | = | == | != | ( | ) | { | } | [ | ] | ^ | | || | ! | /* | */ | : | % | // | ++ | -- | | | += | -= | *= | /+
3.3 数值类型
本语言有7种数值类型,在此将其定义为Value类,EBNF表达如下:
valueType ::= Integer | Char | Real | Boolean
另外有:
digit ::= 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9
Integer ::= digit,{digit}
Real? ::= int,.,int
Char? ::= a | b | c | d | e | f | g | h | i | j | k | l | m | n | o | p | q | r | s | t | u | v | w | x | y | z
Boolean? ::=? 0 | 1
4. 语言语法设计与EBNF
4.1 命令语法
本语言在命令语法中包含完整的变量声明、参数传递、兼容原Pascal的begin-end与Let-in设计结构,同时本语言考虑设计了IF-Then-Else和While-Do当下流行的C语言结构(包含了递归机制的实现),并且考虑异常的错误捕捉设计了Try-Catch的语法结构。
本语言设计的语法结构相比Python会更加的简洁,并且设计的语句Command;Command解决了Python无法一行执行多个语句的缺点,设计重点在于静态编译特性能够高效率的编译执行代码。
本语言将Identifier,Integer_Literal,Character_Literal,Operator为原子操作,不
您可能关注的文档
网络工程师持证人
本人已从事浙江省工程咨询5年,对浙江省内工程信息非常熟悉,可获取新建工程相关联系人、设计院、业主等关键信息。另外从事楼宇自控专业已10年,考取了一建二建等资格证书,有关考试方面的问题(考试心得、方法、学习资料等)都欢饮来咨询交流。
原创力文档


文档评论(0)