运行ANTLR的语法文件会自动生成很多文件:
在编写antlr的语法文件,配置运行路径后就会自动生成如图所示的几个文件,
- SqlBaseParser:该文件包含了一个语法分析器类的定义,这语法分析器是专门用来识别语法文件的。在这个类中,每一条规则独有对应的方法,除此之外,还有一些其他的辅助代码。
public class SqlBaseParser extends Parser{...}
- SqlBaseLexer:ANTLT能够是被语法中的词法和文风规则,这个文件包含了词法分析器的类定义,ANTLR通过分析此法规则 "CL", "CL1", "ID", "WS",以及语法中的字面量{、,}等生成。词法分析器的作用就是将输入的字符序列分解成词汇字符,比如下列代码
public class SqlBaseLexer extends Lexer{...}
- SqlBaseListener;SqlBaseBaseListener: ANTLR生成的语法分析器将输入文本转化成一棵语法分析树,在便利这棵树的时候能够触发一系列的“事件”,并通知我们提供的监听器对象。SqlBaseListener提供的是一些回调的方法的定义,我们可以完成自定义的功能,SqlBaseBaseListener是该接口的默认实现类,为每个方法提供了一个空方法。它的优点在于,这一切都是自动进行的,我们不需要编写对语法分析树的遍历代码,也不需要让我们的监听器显示的访问子节点
- SqlBaseVisitor,SqlBaseVisitor:ANTLR的访问者模式,与上述的监听者模式类似,但是有时候控制遍历语法分析书的时候,通过显示的方法来调用访问子节点。语法中的每一条规则对应了一个visit方法。
- SqlBase.tokens:ANTLR会给我们定义的词法符号指定一个数据类型,然后将他们的对应关系存储到该文件当中,有的时候一个大型的语法要切分成更多个小型的语法,这时这个文件就显得尤为重要。通过这个文件中的内容,ANTLR可以在多个小型预发件同步全部的词法符号类型。
自动生成的tokens文件