- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直在研究编译器。这个词法分析器似乎很简单:采用“句子”并将其分解为单词(或标记)。为了确保正确的语法,需要一个解析器。解析器通常获取 token 并构建一棵树,该树导致一个根节点(单词成句子,段落,页面等)。
从this question看来,解析器将构建AST。 AST仅包含执行代码所必需的内容,因此不需要括号之类的东西,因为AST中内置了运算符优先级。 AST可能是编译器所需的全部。
但是,如何将代码从一种语言转换为另一种语言呢?采用一种组合语言(语法)或现有语法并将其转换为另一种运算符优先规则可能不同的地方? CST是否也“内置”了运营商优先级?
例如,假设我组成了一种语言,并想将其翻译成PHP代码。大多数语言上的三元运算符具有从右到左的关联性。 PHP错误地使用了从左到右的关联性(see more about this here)。我希望“我的语言”从右到左使用,但是生成的PHP代码必须应用括号才能在PHP中获得正确的结果(使用link to Wikipedia,结果需要是“train”而不是“horse”)。
那么对于语言翻译,CST会更好吗?通常将运算符(operator)优先级内置到CST中吗?之间有什么吗?有没有将两个树与一个简单的代数方程进行比较的示例?举例说明三元运算符吗?
(“转码”是“编程语言翻译”的正确术语吗?Google搜索带来了转换媒体。)
我要弄清楚的是:什么时候更合适地使用一个?
最佳答案
您只需要对源语言的所有语义细节进行建模的AST。根据定义,如果它确实正确地对语义建模,并且您的语言包含三元运算符,那么它将也正确地对运算符的应用顺序进行建模(例如,优先级取模的结果(例如括号))。
因此,您的问题不在AST中。它使用优先级不同的类似(三元)运算符生成另一种语言。
这是代码生成中的一个古老问题:目标运算符与源运算符不太匹配,因此输出不能一对一。对于您的情况,您应该能够通过生成带有括号的PHP三元运算符来控制顺序,以实现原始语义,从而解决该问题,所以这不是一个大问题。
通常,生成实现所需结果的代码序列可能非常复杂,并且有很多方法可以实现。这就是为什么编译器书籍比较厚而不是比较薄的原因。您似乎已经隐式地决定“获取AST,浏览AST,输入代码”;这几乎是即时代码生成器。如果您不在乎生成的代码是否特别好,并且目标语言与源语言非常接近,则此方法就足够了。
如果代码生成问题更复杂,通常会使用AST来生成相当于计算的数据流模型的数据,该模型由产生结果的运算符组成,并消耗先前运算符的结果,并以“运算符”为基础获取变量值和常量。然后遍历数据流表示以生成代码。这样的好处是,您可以在数据流表示中选择一个运算符,以目标语言查找匹配的代码序列,生成该序列,然后担心如何收集操作数。更好的方案将数据流子图(表示等效的复合目标语言构造)匹配到生成的数据流图;这样可以产生更好的代码。通常,可以在生成原始代码后应用特定于目标语言的优化,以生成更好的代码。在这两种情况下,您都不必担心管理运算符(operator)结果。可以将它们直接提供给下一个目标语言运算符,还是必须将它们放入某种临时存储区(对于机器代码,这可以是另一个寄存器或存储位置)。要做到这一切并不容易。再次,这就是为什么编译器书籍并不薄的原因。
这种想法的一种变体是源到源程序的转换。尽管通常通过在AST上进行操作来完成此操作,因为未解析的编程语言文本很难匹配,所以此操作将源代码中的结构“直接”映射到目标代码中的结构。我们的DMS Software Reengineering Toolkit是这种系统的一个例子。使用这种工具,您可以用源语言(与分析树隐式匹配)编写模式,并在目标语言(隐式生成目标语言AST)中编写相应的模式。您可以编写复杂的源或目标构造,从而获得上述数据流图匹配的大部分效果。后代优化由更多重写规则组成,这些规则将目标代码转换为目标代码。
底线:除非您的翻译真的很琐碎,否则仅拥有AST还是不够的。
您可以在以下SO答案中了解更多有关您需要做什么的信息:https://stackoverflow.com/a/3460977/120163
警告:大声的意见随之而来。
关于“代码转换器”:我更喜欢术语“编译”,“翻译”或“源到源”编译器。我从事程序分析和操作工具的开发已有近40年的历史了。直到我遇到这个SO问题:Experience migrating legacy Cobol/PL1 to Java和描述IMHO的响应(一种称为NACA的真正糟糕的代码转换方案)之前,我从未听说过“代码转换器”一词。从那以后,我听说这个词正越来越受到人们的欢迎。我不知道为什么在我们有足够的术语时为什么还要发明另一个术语。通常,这表明有人发明了圣职; “让我们发明一个 Shiny 的新名词,这样人们就不会真正了解我们在做什么”。我很乐意将这个术语留给如此糟糕的翻译。
关于compiler-construction - 什么时候使用抽象或具体的语法树?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9456448/
我是 Robert,我在使用 JavaScript 时遇到了一些问题。 我得到了一个 (这是隐藏的)。我唯一想问你的是:我想检查日期是否在 中已通过。如果通过了我想改变CSS中容器的背景颜色。不幸的
所以我的问题是我想要求输入使用扫描仪的信息,但它根本不打印出来。当它显示跳过的扫描仪的值时,Scanner CheeseType = new Scanner(System.in);,我得到 null。
Fe_Order_Items fe_order_items_id fe_order_specification_id fe_users_id fe_menu_items_id fe_order_ite
人们普遍提到 - “Celery 是一个基于分布式消息传递的异步任务队列/作业队列”。虽然我知道如何使用 Celery 工作人员等。但内心深处我不明白分布式消息传递的真正重要性和意义以及任务队列在其中
我试图理解下面的代码,但有一些我以前从未见过的东西,那就是:“\&\&” 这是代码: int main() { fork() \&\& (fork() || fork()); exit(EXIT_SU
您好,我是论坛新手。 我有很多使用 python 的经验,但没有使用 tkinter 的经验。 这是我的代码: from tkinter import * def Done(): celEn
在 C# 中,假设我们有一个通用类和一个具体类 [Serializable] public class GenericUser { ... [Serializable] public class Co
我尝试使用的库有一个通用抽象类,其中有两个实现该基础的子类。我想编写一个类,它将根据构造函数参数的参数类型自动创建其中一个子级的实例。 基类没有默认构造函数 基类的构造函数也需要其他通用类的实例 代码
我是 Angular 的新手,我一直在尝试了解它的工作原理。我正在制作一个简单的应用程序,其中有人可以通过简单的 html 界面添加用户并使用 SQLite 将其存储在数据库中,然后他们可以编辑或删除
我想创建一个用于存储数据的对象,限制读/写访问。 例如: OBJ obj1; OBJ obj2; // DataOBJ has 2 methods : read() and write() DataO
注入(inject)/隔离密封在 dll 中且不实现接口(interface)的类的首选方法是什么? 我们使用 Ninject。 假设我们有一个类“Server”,我们想要注入(inject)/隔离“
在花费了至少 10 个小时的时间浏览在线资源、视频和教程之后,我有两个关于将我的 Android 应用程序与 mySQL 数据库连接的问题。 保存文件 1) 所有教程都将 php 文件保存在 C/WA
许多有经验的开发人员建议不要使用 Django multi-table inheritance因为它的性能不佳: Django gotcha: concrete inheritance通过 Jacob
我知道我冒着挨揍的风险,但我觉得我在这件事上要绕圈子。为了让模型可用于多个项目,我们已将模型移出到一个单独的项目(一个 DLL)中,作为一系列要实现的接口(interface)。我们的界面上有这一行:
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我遇到了一个特定 mac 的问题,它没有显示我正确构建的某个网站。我测试过的所有其他 mac 和 pc 都能正确显示网站,但是在所有浏览器中这个特定的 mac 显示不正确就像提到的那样,这在其他每台计
给定这段代码 public override void Serialize(BaseContentObject obj) { string file = ObjectDataStoreFold
我已经搜索了网络和我的服务器,但我无法找到我网站的 php.ini。我的网站出现以下错误。 Class 'finfo' not found Details G:\inetpub\wwwroot\lan
SQL 爱好者: 我正在尝试通过玩以下用例来挖掘我一些生疏的 sql 技能: 假设我们有一家有线电视公司,并且有跟踪的数据库表: 电视节目, 观看我们节目的客户,以及 观看事件(特定客户观看特定节目的
我正在设计一个使用 HTML5 网络组件(HTML 导入、影子 DOM、模板和自定义 HTML 元素)的网络应用程序,这些组件是通过普通 JavaScript(无框架)实现的。 Web 应用程序相当简
我是一名优秀的程序员,十分优秀!