`
NeuronR
  • 浏览: 60888 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

[任务布置]编译器构造实践

阅读更多

概述

    Jerry 语言总体上来说是 C 语言的子集,满足 Jerry 语言的词法、语法、语义均满足 C 语
言,除了 IO 语句。
    它没有 main 函数,而是从代码第一行开始,直到结束。它也不支持函数调用。
    IO 语句并不是调用函数,使用这样的语句来进行 IO:
           read x;
           write x + 1;
其中 read 和 write 都是 Jerry 语言的关键字。
    支持 if-else(else 可选)条件分支,while 循环语句,以及 break 跳出循环。
    支持四则运算,正负号,比较运算,逻辑运算(“与”“或”运算支持条件短路)。
    支持链式赋值。
    以上各种运算、赋值的优先级与 C 语言一致。
    支持多维数组但是不支持指针。
    语句以分号结尾。允许空语句。
    Jerry 语言将被编译成为二进制字节码,由 Jerry 虚拟机执行。

Jerry 语言中的关键字及作用

int / real        声明变量,前者声明整型变量,后者声明实型变量。
read / write      IO 操作,前者输入,后者输出。
if / else         分支语句使用的关键字,与 C 语言一样
while / break     循环语句使用的关键字,与 C 语言一样

数据类型

    支持两种数据类型:整型(int)和实型(real),分别相当于 C 语言中的整型(int)和双精度浮点(double)。

词法

    变量名称规则跟 C 语言一样。常数整数的形式是十进制数字序列,不支持十六进制或八进制数值。浮点数形式与 C 语言一致。

语法(EBNF)

# Jerry 语言
Jerry -> BasicBlock <END>
# 基本块
BasicBlock -> ε
BasicBlock -> Sentence BasicBlock
# 语句
Sentence -> <EOS>
Sentence -> IfElseBranch
Sentence -> WhileLoop
Sentence -> Declaration
Sentence -> <IO> Variable <EOS>
Sentence -> Assignment <EOS>
Sentence -> <BREAK> <EOS>
Sentence -> <LBRACE> BasicBlock <RBRACE>
# if-else 分支
IfElseBranch -> <IF> <LPARENT> Assignment <RPARENT> BasicBlock ElseBlock
ElseBlock -> <ELSE> BasicBlock
ElseBlock -> ε
# while 循环
WhileLoop -> <WHILE> <LPARENT> Assignment <RPARENT> BasicBlock
# 声明
Declaration -> <TYPE> VariableRegister <EOS>
VariableRegister -> VariableRegister <COMMA> Variable Initialization
VariableRegister -> Variable Initialization
Initialization -> <ASSIGN> Assignment
Initialization -> ε
# 运算相关
# 赋值
Assignment -> Condition <ASSIGN> Assignment
Assignment -> Condition
# 逻辑运算
Condition -> Condition <OR> ConjunctiveCondition
Condition -> ConjunctiveCondition
ConjunctiveCondition -> NegativeCondition
ConjunctiveCondition -> ConjunctiveCondition <AND> NegativeCondition
NegativeCondition -> <NOT> Comparison
NegativeCondition -> Comparison
# 比较运算
Comparison –> Comparison <COMPARATOR> Expression
Comparison -> Expression
# 表达式
Expression -> Expression <OP_MUL_DIV> Term
Expression -> Term
#项
Term –> UnaryFactor
Term -> Term <OP_PLS_MNS> UnaryFactor
# 一元因子, 可能有正负号
UnaryFactor -> SimpleFactor
UnaryFactor -> <OP_PLS_MNS> SimpleFactor
# 简单因子
SimpleFactor -> <INTEGER>
SimpleFactor -> <REAL>
SimpleFactor -> Variable
SimpleFactor -> <LPARENT> Assignment <RPARENT>
# 变量(包括数组下标等信息)
Variable -> <IDENT> Dimensions
Dimensions -> <LBRACKET> Assignment <RBRACKET> Dimensions
Dimensions -> ε

语义限制

break 必须在 while 循环内,且仅跳出当前循环。
比较运算得出的是整型数,为真时值为 1,否则为 0。
整型数或表达式可以为逻辑条件。实型数或表达式不可以为条件。
数组声明时,每一维必须显示给出大小。对数组进行初始化仅对其第一内存单元进行初始化。
赋值的左部及 read 的参数必须是变量引用(这一条非语法限制)。

分享到:
评论
5 楼 lwwin 2009-11-28  
这样是不是有点为难博主了=3=笑

相较于现代人性化语言,其实C语言算比较容易入门了吧^^
4 楼 NeuronR 2009-11-20  
andyjackson 写道
这个jerry语言的语法形式和CMM语言的语法形式接近,而且稍微比CMM复杂一点.
看了帖子之后,发现自己在表达式和VARIABLE的定义上有问题.但是,看你的原程序
有点看不懂,我不懂C,希望你提供写关于C学习的意见

这个这个... 难道你也是whu-iss的? C的学习建议啊, 这个太宽泛了, 看看 C Programming Language, 对计算机体系结构多加学习和理解就好.
3 楼 andyjackson 2009-11-17  
这个jerry语言的语法形式和CMM语言的语法形式接近,而且稍微比CMM复杂一点.
看了帖子之后,发现自己在表达式和VARIABLE的定义上有问题.但是,看你的原程序
有点看不懂,我不懂C,希望你提供写关于C学习的意见
2 楼 NeuronR 2009-02-18  
jindw 写道

调动学生的主动思考习惯,不错的招,呵呵。也就学校里有这种时间啊,以后这也一定是一段值得怀念的经历^_^

嗯,确实很好玩。
1 楼 jindw 2009-02-18  
调动学生的主动思考习惯,不错的招,呵呵。
也就学校里有这种时间啊,以后这也一定是一段值得怀念的经历^_^

相关推荐

    编译原理第一周实验作业参考答案

    中山大学软件学院的编译原理课程第一周实验作业,旨在帮助学生初步接触并理解编译器的基本构造和工作原理。下面将针对这个实验作业的重点和相关知识点进行详细解析。 首先,编译原理是一门研究计算机语言翻译过程的...

    School-Assignments:为学校完成编码作业

    通过以上知识点的学习和实践,学生可以逐步掌握Java编程,并能有效地完成学校布置的各种编程作业。无论是简单的算法实现还是复杂的系统设计,Java都提供了强大而灵活的工具和框架来支持。在“School-Assignments-...

    基于MATLAB GUI的学生成绩管理系统:功能实现与应用

    内容概要:本文介绍了一款基于MATLAB GUI的学生成绩管理系统,旨在提升学校教学管理的效率和准确性。系统主要由三个模块组成:考试收录数据模块、考试数据分析模块和统计分析数据模块。它不仅支持成绩的录入、显示、排序、查找,还包括特征值分析、直方图绘制和教师评语录入等功能。通过对成绩数据的综合分析,系统能为学校教学管理提供客观科学的数据支持。 适合人群:教育工作者(如教师、管理人员)和技术爱好者(特别是对MATLAB GUI感兴趣的开发者)。 使用场景及目标:适用于各类学校和教育机构,用于管理和分析学生成绩,帮助教师和管理者更好地了解学生的学习状况,改进教学质量。 阅读建议:对于希望深入了解如何利用MATLAB GUI进行学生成绩管理的读者来说,本文提供了详细的系统设计思路和功能实现方法,值得仔细研读并尝试实践。

    基于T-Mats库的涡扇发动机气路故障仿真模型:自定义故障植入与真实运行扰动分析

    内容概要:本文介绍了基于T-Mats库的涡扇发动机气路故障仿真模型,涵盖了多种类型的故障植入(如部件流量、效率及压比故障),并允许自定义故障程序和组合。该模型通过对软阈值去噪处理后的信号序列进行分析,提取真实的运行扰动信息,确保输出数据符合CMAPASS的排列要求。此外,该模型能够模拟航空发动机的典型气路故障,帮助研发和技术人员更准确地预测和评估发动机性能,从而提前采取预防措施。 适合人群:航空航天领域的研发人员、技术人员以及对航空发动机故障仿真感兴趣的学者。 使用场景及目标:①用于研究和开发涡扇发动机的气路故障诊断系统;②辅助工程师进行故障预测和性能评估;③为后续数据分析和实验验证提供可靠的数据基础。 其他说明:该模型不仅提高了仿真的准确性,还增强了对发动机运行状态的理解,为提升发动机性能和可靠性提供了强有力的技术支持。

    scratch少儿编程逻辑思维游戏源码-scratch冒险.zip

    scratch少儿编程逻辑思维游戏源码-scratch冒险.zip

    少儿编程scratch项目源代码文件案例素材-爬塔.zip

    少儿编程scratch项目源代码文件案例素材-爬塔.zip

    合金凝固模型中的相场模拟与各向异性枝晶生长研究及其在激光增材制造中的应用

    内容概要:本文详细探讨了合金凝固模型中的相场模拟方法及其在各向异性枝晶生长研究中的应用。首先介绍了合金凝固模型的基本概念及其在现代制造业中的重要性,特别是在激光增材制造、选择性激光熔融和定向凝固技术中的应用。接着,重点讨论了相场模拟作为一种数值模拟方法,在预测合金凝固过程中组织结构演变方面的关键作用。文中还提供了MATLAB实现合金各向异性枝晶生长的具体代码及详细注释,以及Comsol用于偏微分方程求解的雪花生长模型。最后,文章总结了当前的研究进展,并展望了未来的发展趋势。 适合人群:从事材料科学、冶金工程、激光增材制造领域的研究人员和技术人员,尤其是对相场模拟和合金凝固感兴趣的学者。 使用场景及目标:适用于希望深入了解合金凝固过程、相场模拟方法及其在现代制造技术中应用的专业人士。目标是提高对合金凝固机制的理解,优化制造工艺,提升产品质量。 其他说明:文章不仅提供了理论分析,还包括具体的代码实现和详细的文献参考资料,有助于读者全面掌握相关技术和最新研究进展。

    少儿编程scratch项目源代码文件案例素材-史莱姆出击.zip

    少儿编程scratch项目源代码文件案例素材-史莱姆出击.zip

    少儿编程scratch项目源代码文件案例素材-忍者酷跑.zip

    少儿编程scratch项目源代码文件案例素材-忍者酷跑.zip

    scratch少儿编程逻辑思维游戏源码-点击灌篮.zip

    scratch少儿编程逻辑思维游戏源码-点击灌篮.zip

    基于RBF神经网络的PID控制器在PMSM转速环中的Simulink模型设计与性能分析

    内容概要:本文介绍了将基于RBF神经网络的PID控制器应用于永磁同步电机(PMSM)转速环控制的方法及其性能优势。传统的PID控制器在面对非线性和时变系统时存在参数整定困难的问题,而引入RBF神经网络可以实现实时在线调参,提高系统的灵活性和鲁棒性。文中详细描述了Simulink模型的设计,特别是Matlab s-function模块中RBF神经网络的具体实现,包括高斯函数激活和带惯性的权值更新机制。实验结果显示,在转速突变情况下,改进后的控制器能够迅速稳定系统,超调量控制在2%以内,调节时间较传统方法缩短约40%,并且在负载变化时表现出色,无需重新整定参数。 适合人群:从事电机控制系统研究和开发的技术人员,尤其是对PID控制器优化感兴趣的工程师。 使用场景及目标:适用于需要提升PMSM转速环控制精度和响应速度的应用场合,如工业自动化设备、机器人等领域。目标是通过引入智能算法解决传统PID控制器参数整定难题,提高系统性能。 阅读建议:关注RBF神经网络与PID控制器结合的具体实现细节,特别是在Matlab s-function模块中的编码技巧以及参数调整策略。同时,注意学习率的选择和动量项的作用,这对于实际应用至关重要。

    scratch少儿编程逻辑思维游戏源码-Scratch 奔跑.zip

    scratch少儿编程逻辑思维游戏源码-Scratch 奔跑.zip

    基于COMSOL有限元仿真的变压器辐射传热数值分析:从入门到进阶

    内容概要:本文详细介绍了基于COMSOL有限元软件的变压器辐射传热数值分析方法。首先,解释了变压器内外辐射传热的基本机理,包括热量通过传导、对流和辐射的方式传递,重点在于辐射传热的作用及其数学描述。接着,逐步引导读者从零开始构建有限元仿真模型,涵盖模型参数确定、网格划分、材料属性定义、边界条件设置、传热方程设定、仿真运行及结果分析等多个步骤。最后,探讨了进一步研究的方向,如不同因素(温度、材料属性、几何形状)对辐射传热的影响,以及该模型在电力电子设备和热管理系统的潜在应用。 适合人群:电气工程专业学生、初学者和技术爱好者,尤其是对有限元仿真和变压器辐射传热感兴趣的群体。 使用场景及目标:适用于希望通过实际操作掌握有限元仿真技能的人群,旨在帮助他们理解变压器辐射传热机制并能独立完成相关仿真项目。 其他说明:本文不仅提供了理论知识,还附带了详细的视频教程和仿真模型,使学习过程更加直观易懂。

    交错并联Boost PFC仿真电路模型:基于双闭环控制的BCM模式优化与应用

    内容概要:本文详细介绍了交错并联Boost PFC(功率因数校正)仿真电路模型的设计与实现,特别是在临界BCM模式下的双闭环控制特性。文章首先解释了该电路的经典结构及其优势,即能够有效降低开关损耗和电流纹波。接着,重点讨论了双闭环控制的具体实现方法,包括外环电压控制和内环电流控制的MATLAB/Simulink代码示例。文中还特别强调了电流环中零交叉检测的重要性以及交错并联结构中驱动信号相位差的精确设置。此外,作者分享了将模型从Simulink转换到Plecs和Psim时遇到的问题及解决方案,如更换为带反向恢复特性的二极管模型和重新校准控制环路的采样周期。最后,文章展示了优化后的电流波形图,验证了所提方法的有效性。 适合人群:电力电子工程师、电源设计师、从事电力系统仿真的研究人员和技术爱好者。 使用场景及目标:适用于需要进行高效电源设计的研究和开发项目,旨在提高电源系统的性能,减少谐波失真,提升功率因数校正效果。 其他说明:文中提供的具体代码片段和参数设置有助于读者更好地理解和复现实验结果。同时,对于希望深入理解双闭环控制系统和BCM模式的人来说,本文提供了宝贵的实践经验。

    scratch少儿编程逻辑思维游戏源码-3000 横版闯过.zip

    scratch少儿编程逻辑思维游戏源码-3000 横版闯过.zip

    空气涡轮发动机Matlab/Simulink动态仿真模型:部件级建模与PID控制应用

    内容概要:本文介绍了如何利用Matlab/Simulink构建空气涡轮发动机的动态仿真模型。首先,文章详细阐述了各个部件级模型的设计,包括进气道、涡轮、气室、压气机、尾喷管、转子动力学模块和容积模块。接着,重点讨论了PID控制器在维持发动机转速恒定方面的作用,尤其是在面对输出扭矩阶跃扰动时的表现。最后,提供了简单的Simulink模型代码片段,展示了如何设置和运行仿真模型,以便实时监控和调整发动机性能。 适合人群:航空航天工程领域的研究人员和技术人员,尤其是那些对空气涡轮发动机仿真感兴趣的读者。 使用场景及目标:适用于希望通过Matlab/Simulink进行空气涡轮发动机仿真研究的专业人士。主要目标是掌握空气涡轮发动机各部件的工作原理及其相互关系,同时学会使用PID控制器优化发动机性能。 其他说明:本文不仅提供了理论知识,还附有实际操作步骤和代码示例,帮助读者更好地理解和应用所学内容。

    少儿编程scratch项目源代码文件案例素材-收集能量.zip

    少儿编程scratch项目源代码文件案例素材-收集能量.zip

    scratch少儿编程逻辑思维游戏源码-弹回的球.zip

    scratch少儿编程逻辑思维游戏源码-弹回的球.zip

    少儿编程scratch项目源代码文件案例素材-铅笔画.zip

    少儿编程scratch项目源代码文件案例素材-铅笔画.zip

    Sage Decrypter.zip

    Sage Decrypter.zip

Global site tag (gtag.js) - Google Analytics