词法分析器Antlr

本文深入探讨了Java和JavaScript在不同虚拟机中的编译过程,介绍了编译的基本步骤,并通过ANTLR这一功能强大的语言识别工具,展示了其在自动生成词法分析器、语法分析器和树分析器方面的卓越能力。

  一、我们都知道编程语言在执行之前需要先进行编译,这样就可以把代码转换成机器识别的语言,这个过程就是编译。

  那么它是怎么编译的呢?

  Java在JVM虚拟机中进行编译,javascript在Js引擎中编译。 

  编译的过程一般是三个步骤:

    1.分词/词法分析(Tokenizing/Lexing)

  这个过程会将由字符串分解成(对编程语言来说)有意义的代码块,这些代码块被称为词法单元(token)。

    2.解析/语法分析(Parsing)

  这个过程是将词法单元流(数组)转换成一个由元素逐级嵌套所组成的代表程序语法结构的树。这个树被称为抽象语法树。

    3.代码生成

  将AST转换为可执行代码的过程被称为代码生成。这个过程与语言、目标平台等信息相关。

  二、Antlr 是一个基于 Java 开发的功能强大的语言识别工具,Antlr 以其简介的语法和高速的运行效率在这类工具中出类拔萃。

  在 Antlr 中通过解析用户自定义的上下文无关文法,自动生成词法分析器 (Lexer)、语法分析器 (Parser) 和树分析器 (Tree Parser)。

  来源:《你不知道的javascript》、IBM中文社区http://www.ibm.com/developerworks/cn/java/j-lo-antlr/

转载于:https://www.cnblogs.com/sun-rain/p/5021286.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值