- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
谈谈Java抽象语法树的构建
谈谈Java 抽象语法树的构建
抽象语法树 (abstract syntax tree, AST )是程序的一种中间表示形式,是源代码抽象语法结构的树状表
现形式。树上的每个结点都代表一种语法结构。之所以称语法是“抽象”的,是因为这里的语法并不会表
示出真实语法中的每个细节。比如,嵌套括号被隐含在树的结构中,并没有以结点的形式呈现,而类似于
if-than-else 这样的条件语句,可以用两个分支结点表示。本文将谈谈Java 抽象语法树构建方面有哪些常用
的 (解析)工具,重点探讨JDT 的工作机制和配置方法。
当前,将java 程序转化成抽象语法树的工具较多,比如,JDT (/jdt/) 、ANTLR
(/) 、RECODER (/projects/recoder/) 以及JavaCC (/)等,
其中RECODER 更新较慢,从2013 年开始停止发布新版本。在这几款工具中,由于JDT 工具为开源软件,
在学术界越来越受欢迎。JDT (Java Development Tools )是Eclipse 中一组Java 开发工具包,它由JDT Core 、
JDT Debug 以及JDT UI 插件组成,这3 个插件均提供了API 供开发者调用,以支持开发者进一步开发基于
JDT 的其它插件。顾名思义,插件JDT Core 是JDT 的核心包,它提供了整个Eclipse 的核心基础功能,比
如,Eclipse 菜单下的Refactor 操作,其功能的实现都依赖该核心包。另外,这些插件均以jar 文件的形式发
布,在下载的Eclipse 文件夹plugins 下可以直接获得,如果你想获取,只需要搜索类似于下面的jar 文件即
可:org.eclipse.jdt.launchingXX.jar, org.eclipse.jdt.uiXX.jar, org.eclipse.jdtXX.jar ,这里的XX 代表每个插件发
布的版本号。
在插件JDT Core 的org.eclipse.jdt.core.dom 包中,含有AST 、ASTParser、ASTNode 、ASTVisitor 等类,
通过这些类可以获取、创建、访问和修改抽象语法树。比如,ASTVisitor 类就提供了一系列重载visit 函数,
用于遍历抽象语法树,以获得AST 上每个结点信息。
为了形象地理解AST ,下面通过一个具体的程序 (Circle.java)说明AST 的结构以及结点的类型。
package a.b.c;
import .Shape;
public class Circle {
private final double pi = 3.14;
public double getSqure (double r) {
double result = pi*r*r;
return result;
}
}
图1 Circle.java 对应的AST ,为清晰起见,图1 中“粗体”标识的叶子结点并未详细展开。图中的每个
AST 结点均代表程序中相应的程序单元或语法结构。其中,位于最顶层的CompilationUnit 结点代表源程序
文件 (Circle.java);TypeDeclaration 结点代表Circle 类;FieldDeclaration 结点代表Circle 类中的属性声明和
初始化语句 “private final double pi = 3.14; ”;MethodDeclaration 结点表示getSqure 方法的声明与实现语句;
ReturnStatement 结点表示返回语句 “return result;”,总之,AST 中的每个结点均代表相应的Java 语法结构
(有时也称代码实体),在JDT 中共有92 种AST 结点类型,具体可访问API 文档查看相关信息。
CompilationUnit
PACKAGE IMPORTS TYPES
PackageDeclaration ImportDeclaration TypeDeclaration
MODIFIERS NAME
您可能关注的文档
最近下载
- DL∕T 5168-2023表A.5 分部工程质量控制资料核查记录.pdf VIP
- 大班数学活动《8的分解组成》PPT课件.ppt
- 【一模】2025年广东省2025届高三高考模拟测试 (一) 数学试卷(含官方答案及解析 ).docx
- 13S201 室外消火栓及消防水鹤安装.docx VIP
- 主题班会课件-师恩难忘-学子感恩-致敬恩师主题班会.ppt
- GB50327-2001住宅装饰装修工程施工规范.docx
- World怎么在参考文献后面添加CrossRef.pdf VIP
- 江苏省房屋建筑和市政基础设施工程标准施工招标文件(适用于资格后审).doc VIP
- 八下英语U3词性变化.docx
- 《机械原理》期末考试试题及答案.docx
文档评论(0)