带有内部枚举类的 Eclipse AST 的奇怪结果

sin*_*ina 5 java abstract-syntax-tree eclipse-jdt

我正在试验 eclipse jdt AST 并且遇到了一种我无法解释的奇怪行为。

这是我的示例代码:

public static void main(String[] args) {
    StringBuilder content = new StringBuilder();
    content.append("class Foo {");
    content.append("    enum Bar {");
    content.append("        VALUE;");
    content.append("        int getValue() {");
    content.append("            return 4;");
    content.append("        }");
    content.append("    }");
    content.append("    int getValue() {");
    content.append("        return 42;");
    content.append("    }");
    content.append("}");

    ASTParser parser = ASTParser.newParser(AST.JLS13);
    parser.setKind(ASTParser.K_COMPILATION_UNIT);
    parser.setSource(content.toString().toCharArray());

    CompilationUnit astNode = (CompilationUnit) parser.createAST(null);

    Visitor rtVisitor = new Visitor();
    astNode.accept(rtVisitor);

}

private static class Visitor extends ASTVisitor {

    @Override
    public boolean visit(TypeDeclaration node) {
        System.out.println(node);
        return super.visit(node);
    }
}
Run Code Online (Sandbox Code Playgroud)

如您所见,我正在定义一个非常简单的示例类,它有一个内部枚举类,其中两个类都有一个具有相同签名的方法。

奇怪的是,虽然这段代码的输出(即 parsed TypeDeclaration)是

class Foo {
  enum Bar;
{
  }
  int getValue(){
    return 4;
  }
{
  }
  int getValue(){
    return 42;
  }
}
Run Code Online (Sandbox Code Playgroud)

出于某种原因,主体TypeDeclaration包括:

  1. 一个FieldDeclarationenum Bar;
  2. 一个Initializer{}
  3. 一个MethodDeclarationint getValue(){ return 4; }
  4. 另一个Initializer{}
  5. 另一个MethodDeclarationint getValue(){ return 42; }

这导致我的实际代码抛出错误,因为看起来有两个具有相同签名的方法。

为什么我没有将枚举作为EnumDeclaration内部方法的实际值,而是看起来枚举中的方法实际上是在外部类本身中声明的?

我不认为这是一个错误,因为 Eclipse 中的 AST 视图可以完美地处理类似的类,但我无法弄清楚我做错了什么。启用绑定解析没有帮助。

mce*_*nak 2

您需要通过调用设置编译器选项parser.setCompilerOptions,以便正确处理源文件。
由于您使用的是enum关键字,因此您至少需要符合 Java 5:

ASTParser parser = ASTParser.newParser(AST.JLS13);
Map options = JavaCore.getOptions();
JavaCore.setComplianceOptions(JavaCore.VERSION_1_5, options);
parser.setCompilerOptions(options);
parser.setKind(ASTParser.K_COMPILATION_UNIT);
parser.setSource(content.toString().toCharArray());
Run Code Online (Sandbox Code Playgroud)