如何在基于抽象语法树的解释器中表示类

发布于 2024-07-21 08:25:57 字数 233 浏览 11 评论 0原文

我已阅读相关问题,但似乎没有一个问题能直接解决该问题。 我正在编写一个 PHP 脚本解释器。 我让 AST 为除类之外的所有内容生成正确的节点。 处理类与处理函数有点不同,因此我正在寻找如何处理独立的类以及扩展其他类的类。

我看过 ANTLR,但我负担不起开销,因为这是针对嵌入式平台的。 我正在寻找的是 AST 中类背后的概念理论,以便它们可以由解释器的执行器部分执行。 非常感谢包含此问题具体答案的良好链接。

I have read the related questions, but none of them appears to address the question directly. I am working on writing a PHP script interpreter. I have the AST generating proper nodes for everything except classes. Handling classes is a bit different than handling functions, so I am looking for how to handle classes that are standalone, and that extend other classes.

I have looked at ANTLR, but I can't afford the overhead as this is for an embedded platform. What I am looking for is the theory conceptually behind classes in ASTs so they can be executed by the executor portion of the interpreter. Good links with specific answers to this issue are definitely appreciated.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

七堇年 2024-07-28 08:25:57

ANTLR 或多或少与您的问题无关。

PHP 中的类基本上是从字符串到属性的映射。 每个属性可以是公共的、私有的、受保护的。 每个属性还保存一个值,该值可以是静态变量或方法。 方法是(在 PHP 中)采用隐式 $this 参数的函数。 因此,您可以将类基本上视为 PHP 中的一个奇特的数组对象。

当您创建一个对象时,您给它一个指向 PHP 类对象的指针。 当您调用该对象上的方法时,您可以通过通过该指针获取的类对象查找该方法。

我希望这有帮助。

ANTLR is more or less irrelevant to your problem.

A class in PHP is basically a map from strings to attributes. Each attribute can be public, private, protected. Each attribute also holds a value, which could be a static variable or a method. Methods are functions that (in PHP) take an implicit $this parameter. So you can think of a class as basically a fancy array object in PHP.

When you create an object, you give it a pointer to your PHP class object. When you call a method on that object, you look up the method through the class object which you get through that pointer.

I hope this helps.

无语# 2024-07-28 08:25:57

也许您需要一些与源语法稍微分离的解释结构? 我对 PHP 了解不多,但听起来您确实在问如何以方便解释的方式构建程序模型。 我认为通过 ANTLR 生成的 AST 与您想要的源有点太接近了。

Perhaps you need some structures for interpretation that are a bit more removed from the source grammar? I don't know much about PHP, but it sound like you're really asking how structure the program model in a way that's convenient for interpretation. I'd regard an AST generated via ANTLR as a bit too close to the source for what you want.

み青杉依旧 2024-07-28 08:25:57

我发现自上而下编译器中的最佳方法是将类视为函数,因为它们只是节点,无需在下降到树中之前评估参数。

区别在于执行器,它必须创建一个执行范围,在其中封装构成类节点的方法和变量。

I have found that the best method in a top down compiler, the best method is to treat the classes generally just like functions, in that they are just nodes without needing to evaluate the arguments before descending into the tree.

The differences are in the executor, which has to create an execution scope in which to encapsulate the methods and variables that comprise the class node.

沉默的熊 2024-07-28 08:25:57

我建议使用 JavaCC(或 FreeCC 的分支)来解析和构建 AST。 JavaCC 生成一个没有运行时依赖性的解析器。 编写比 JavaCC 生成的代码更小/更快的解析器很困难。

I'd suggest using JavaCC (or the fork FreeCC) to parse and build your AST. JavaCC generates a parser which has no runtime dependencies. It's difficult to write a smaller/faster parser than the code which JavaCC generates.

冷弦 2024-07-28 08:25:57

看一下 phc 抽象语法,它正是这样做的。 (顺便说一句,听起来使用 phc 的前端可能比重新发明轮子更好)。

Class_def ::= Class_mod CLASS_NAME extends:CLASS_NAME? implements:INTERFACE_NAME* Member* ;
Class_mod ::= "abstract"? "final"? ;

Interface_def ::= INTERFACE_NAME extends:INTERFACE_NAME* Member* ;

Member ::= Method | Attribute ;

Method ::= Signature Statement*? ;
Signature ::= Method_mod is_ref:"&"? METHOD_NAME Formal_parameter* ;
Method_mod ::= "public"? "protected"? "private"? "static"? "abstract"? "final"? ;
Formal_parameter ::= Type is_ref:"&"? var:Name_with_default ;
Formal_parameter ::= Type is_ref:"&"? var:Name_with_default ;
Type ::= CLASS_NAME? ;
Name_with_default ::= VARIABLE_NAME Expr? ;

Attribute ::= Attr_mod vars:Name_with_default* ;
Attr_mod ::= "public"? "protected"? "private"? "static"? "const"?  ;

Take a look at the phc abstract grammar, it does exactly that. (Incidentally, it sounds like using phc's front-end might be better than reinventing the wheel).

Class_def ::= Class_mod CLASS_NAME extends:CLASS_NAME? implements:INTERFACE_NAME* Member* ;
Class_mod ::= "abstract"? "final"? ;

Interface_def ::= INTERFACE_NAME extends:INTERFACE_NAME* Member* ;

Member ::= Method | Attribute ;

Method ::= Signature Statement*? ;
Signature ::= Method_mod is_ref:"&"? METHOD_NAME Formal_parameter* ;
Method_mod ::= "public"? "protected"? "private"? "static"? "abstract"? "final"? ;
Formal_parameter ::= Type is_ref:"&"? var:Name_with_default ;
Formal_parameter ::= Type is_ref:"&"? var:Name_with_default ;
Type ::= CLASS_NAME? ;
Name_with_default ::= VARIABLE_NAME Expr? ;

Attribute ::= Attr_mod vars:Name_with_default* ;
Attr_mod ::= "public"? "protected"? "private"? "static"? "const"?  ;
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文