当前位置: 首页 > article >正文

java-在idea中antrl的hello world

java-在idea中antrl的hello world

    • 1. 在idea中安装ANTLR V4的插件
    • 2. 下载ANTLR的jar包
    • 3. idea中创建普通的java项目
    • 4. 创建一个Hello.g4的文件
    • 5. 使用idea生产接口文件
    • 6. java创建一个类和main方法
    • 7. 调试输出
    • 8. 参考链接

1. 在idea中安装ANTLR V4的插件

路径如下,安装完成后重启idea。

File—settings—搜索Plugins—安装ANTLR V4

重启idea后,会在idea的左下角多出两个antlr的调试窗口:ANTLR Preview和Tool Ooutput。同时也会对.g4文件进行语法识别。

2. 下载ANTLR的jar包

这里下载的是antlr4-4.13.2-complete.jar,可以通过如下链接下载:

https://repo1.maven.org/maven2/org/antlr/antlr4/4.13.2/

3. idea中创建普通的java项目

将下载的antlr4-4.13.2-complete.jar包引入到项目中

4. 创建一个Hello.g4的文件

这个文件可以创建任何地方,每一个规则都是以;结尾,具体内容如下:

grammar Hello;
line:'hecccc' ID;
ID:[a-z]+;
WS:[ \t\r\n]+ -> skip;

第一行:grammar Hello,表示这个语法规则的名称,这个名字要和文件名字一致
第三行:‘hecccc’ ID,表示匹配有hecccc的字符串,hecccc后面跟着的是ID,ID的正则表示小写字母
第六行:WS: [ \t\r\n]+ -> skip ,表示换行、tab键盘的符号,直接忽略

5. 使用idea生产接口文件

选中Hello.g4,右键点击Gerneral ANTRL Regonizer,就会在项目的根目录生成一个gen目录,里面就是接口文件。然后将该文件设置为Sources。

6. java创建一个类和main方法

查看语法分析树

import org.antlr.v4.runtime.CharStream;
import org.antlr.v4.runtime.CharStreams;
import org.antlr.v4.runtime.CommonTokenStream;
import org.antlr.v4.runtime.Lexer;
import org.antlr.v4.runtime.tree.ParseTree;

public class main {
    public static void main(String[] args) {

        CharStream input = CharStreams.fromString("hello eeee");
        Lexer lexer = new HelloLexer(input);

        CommonTokenStream commonTokenStream = new CommonTokenStream(lexer);
        HelloParser helloParser = new HelloParser(commonTokenStream);
        ParseTree parseTree = helloParser.line();

        int childCount = parseTree.getChildCount();
        System.out.println(parseTree.toStringTree());
        for (int i = 0; i < childCount; i++) {
            System.out.println(parseTree.getChild(i));
        }
    }
}

上面代码具体分析见另外一篇文章

https://blog.csdn.net/m0_60688978/article/details/141961105

7. 调试输出

比如我输入字符hecccc dggggggrrgfgggg,就会返回结果匹配

([] hecccc dggggggrrgfgggg)
hecccc
dggggggrrgfgggg

比如我输入字符hecccc dggggg33grrgfgggg,就会返回结果部分匹配

line 1:13 token recognition error at: '3'
line 1:14 token recognition error at: '3'
([] hecccc dggggg)
hecccc
dggggg

比如我输入字符hec dggggg33grrgfgggg,就会返回结果部分匹配

line 1:0 missing 'hecccc' at 'hec'
([] <missing 'hecccc'> hec)
<missing 'hecccc'>
hec

8. 参考链接

手动下载jar包链接

https://repo1.maven.org/maven2/org/antlr/antlr4/4.13.2/

antrl官网

https://github.com/antlr/antlr4/blob/master/doc/java-target.md


http://www.kler.cn/a/294170.html

相关文章:

  • react 受控组件和非受控组件
  • 实验5:网络设备发现、管理和维护
  • 传奇996_19——常用函数
  • React中 修改 html字符串 中某些元素的属性
  • 时序论文20|ICLR20 可解释时间序列预测N-BEATS
  • react 中 useContext Hook 作用
  • 63、Python之函数高级:装饰器缓存实战,优化递归函数的性能
  • Spring Boot启动卡在Root WebApplicationContext: initialization completed in...
  • TulingMember进销存系统
  • Save OpenAI response in Azure function to Blob storage
  • 简单上手 PIPENV
  • 2024高教社杯数学建模国赛ABCDE题选题建议+初步分析
  • 计算机网络-VRRP工作原理
  • kubelet 探针
  • Vue3:实现路径变量
  • 同时播放多个视频
  • Spring Cloud Gateway整合基于STOMP协议的WebSocket实战及遇到问题解决
  • 基于单片机的家居环境监测系统的设计
  • 项目7-音乐播放器7(测试报告)
  • MATLAB 中的矩阵拼接技巧
  • bash反弹shell分析
  • C#编程语言及.NET 平台快速入门指南
  • Facebook群控系统,零门槛营销
  • 基于人工智能的聊天情感分析系统
  • 使用Selenium WebDriver捕获网络请求
  • 【60天备战软考高级系统架构设计师——第七天:架构风格】