- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 C++ 实现编程语言,我即将进入 AST 生成阶段。
我想使用一个三步程序:
例如,这是变量声明的内容:
var MyVar : integer = 8 + 2;
临时形式(右值/节点/左值):
left:
-left:
"MyVar"
-node:
":"
-right:
"integer"
node:
"="
right:
-left:
"8"
-node:
"+"
-right:
"2"
表示为经典 AST:
"="
/ \
/ \
/ \
":" "+"
/ \ / \
/ \ "8" "2"
/ \
"MyVar" "integer"
然后,将临时树添加到全局树中,指定声明的类型:
[EXP]
|
VarDecl
|
{ ... }
这适用于除函数声明和函数调用之外的所有内容:
func add(a : integer, b : integer) : integer;
add(8, 2);
的确,对于这种类型的表达式,没有节点来区分左值和右值。我也不知道如何表示函数参数。我想到了这样的事情:
left:
"add"
params:
[
-left:
"a"
-node:
":"
-right:
"integer"
]
[
-left:
"b"
-node:
":"
-right:
"integer"
]
node:
":"
right:
"integer"
通话同上:
left:
"add"
params:
[
"8"
]
[
"2"
]
但我觉得如果我这样做就没有逻辑了。
所以,我想知道是否有一种接近我的方法来改进它,或者是否必须完全修改我的方法。
PS:我在抽象语法分析和树领域还很陌生,但我已经阅读了很多关于这个主题的文档和教程。
最佳答案
首先,我会建议研究 C++ 的 bison/flex 或其他解析器生成器,因为您可以更轻松地将语句分组到树结构中。
对于函数参数问题,AST 不仅仅是右节点左。您可以在一个节点下有多个(> 2)个分支,并将这些分支视为它们的语法表达式而不是文字字符。这是词法分析器提供帮助的地方,因为您可以将字符抽象为标记,然后解析器会将标记抽象为语法结构。一般来说,像 a : integer
这样的东西应该被抽象成一个语法结构,可能是所谓的类型化声明。
所以 func add(a : integer, b : integer) : integer;
是真的
函数标识符(参数):返回类型
AST中的节点可以跟踪特定信息。
即您的 AST 应该使用“字符”或“标记”,但内部节点应该是语言语法结构的抽象。特别是对于参数列表,我建议将其作为逗号分隔的类型声明列表,然后 params 节点将有一个子节点声明节点列表。
同样从你关于将语句添加到全局树的声明中,将其视为将语句添加到全局 AST 列表可能更有用。
无论如何,这是一个奇怪的答案,希望对您有所帮助。
关于c++ - 对函数 AST 声明的抽象格式的混淆,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51823281/
我对 java 中的抽象有点困惑。 我查了很多页面说抽象就是数据隐藏(隐藏实现)。 我对抽象的理解是它是“部分实现”。只需在抽象类/接口(interface)中定义您需要的内容,然后扩展/实现它们并添
我是 Ruby 的新手,主要来自 C# 和 ActionScript 3(以及其他语言)。我对抽象功能很好奇。具体来说,包装和抽象 Ruby 的 FTP 和 SFTP 库。 我四处搜索,发现了一个名为
目录 Java基础知识(抽象) 抽象 抽象定义 abstract的使用 定义抽象类
这个月我花了一些时间与 Emacs Lisp 进行斗争,试图获得更好地满足我需求的自动缩进。令人惊讶的是,大多数缩进代码是多么低级。我只看到了很少的抽象,例如 搜索不在字符串或注释中的第一个正则表达式
我有以下内容: public abstract class Foo{ //contents of Foo // ... public class Bar extends
我有三个类(class)(A 类、B 类和 C 类)。 类 A 调用 B 的实例并运行 start()。 B类扩展了Thread,因此当调用start()时,run()方法中的任何内容都会被执行。 在
这个问题已经有答案了: Calling a subclass method from superclass (5 个回答) 已关闭 7 年前。 Klasse1是一个抽象类,有一个 foo()方法。 K
我有一个这样的函数: def test(): x = "3" # In actual code, this is computed if x is None: retu
我有两个基类之间的关系: public abstract class RecruiterBase { // Properties declare here // Constructors de
这是我第一次发帖,但我遇到了很多问题。我目前有一个带有标题的 AbstractDevice 类: public abstract class AbstractDevice> implements De
我有一个 MotorDefinition 类和一个名为 Motor 的抽象类: class MotorDefinition { public: MotorDefinition(int p1,
是否有任何方法可以在这种代码(sass)中制定 css 的抽象规则: #cottage-image-gallery input:nth-of-type(1):checked ~ label:nth-o
是否可以声明一个已知的基类型并允许传输所有派生类型? [ServiceContract] public interface IService { [OperationContract]
我目前正在为基于 Java 的文本游戏开发角色生成机制,但我遇到了一个问题,看不出哪里出了问题。我有一个“Character”类,它是抽象的,然后是另一个类“NPCharacter”,它是建立在这个之
抱歉,标题令人困惑。不太确定如何表达它,这可能是问题所在! 我正在寻找一个好的抽象来用于涉及并发线程的情况。 我已经接近了,但还不是很清楚。 稍微简化一下,我在 Android 手机上收集了两种传感器
提前感谢您阅读本文。我不完全理解如何/何时使用摘要,所以我试图在我从事的每个项目中考虑它,看看它是否会在某一天全部点击 Smile | :) 此外,可访问性级别(私有(private)、 protec
我正在探索用于生成 Web 内容的 XML -> XSLT -> HTML 模因。我的 XSLT 经验很少。 我很好奇 XSLT 中有哪些机制可用于处理抽象或“重构”。 例如,使用通用 HTML 和服
在这些谈话中 Nicholas Zakas和 Addy Osmani他们讨论了在构建大型 Javascript 应用程序时将外观模式用作沙箱的想法,以便将应用程序与底层基础库分离。 这种解耦理论上允许
我使用C++和CUDA/C,想为特定问题编写代码,但遇到了一个非常棘手的简化问题。 我在并行编程方面的经验不容忽视,但相当有限,我无法完全预见到此问题的特殊性。 我怀疑是否有一种方便甚至“轻松”的方式
假设我有: trait A class B extends A class C extends A 有没有办法配置类型参数: class Foo[AType <: A with canCreateIn
我是一名优秀的程序员,十分优秀!