我正在尝试使用Java.g4语法和Antlr4解析Java类文件。
有一个特殊的解析器规则,如下所示:

classOrInterfaceType
:   Identifier typeArguments? ('.' Identifier typeArguments? )*
;


我以这种方式在访问者类中解析它:

public String visitClassOrInterfaceType(JavaParser.ClassOrInterfaceTypeContext ctx) {
    StringBuilder clsIntr = new StringBuilder("");
    int n = ctx.getChildCount();
    for(int i = 0; i < n; i++){
        TerminalNode id = ctx.Identifier(i);
        if(id!=null){
            clsIntr.append(id.getText()).append(" ");
        }
        TypeArgumentsContext typArgCtx =ctx.typeArguments(i);
        if(typArgCtx!=null){
            String val = this.visitTypeArguments(typArgCtx);
            clsIntr.append(val);
        }
    }
    return clsIntr.toString();
}


这是正确的还是有其他方法可以做到这一点?

最佳答案

您的方法看起来不错,即使这最终取决于您实际要执行的操作。我的水晶球告诉我,您尝试通过解析树来重建原始查询文本。但是,您可以轻松得多。每个解析上下文都有start和stop成员,这些成员持有此上下文代表的解析文本范围的标记。您可以使用它们直接获得与输入时完全相同的原始文本(通过令牌流和令牌的位置)。

10-08 13:07