问题描述
我正在尝试使用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);
}
}
如您所见,我正在定义一个非常简单的示例类,该类具有一个内部枚举类,其中两个类都具有具有相同签名的方法。
奇怪的是,此代码的输出(即经过解析的TypeDeclaration
)是
class Foo {
enum Bar;
{
}
int getValue(){
return 4;
}
{
}
int getValue(){
return 42;
}
}
- 一个
FieldDeclaration
:enum Bar;
- 一个
Initializer
:{}
- 一个
MethodDeclaration
:int getValue(){ return 4; }
- 另一个
Initializer
:{}
- 另一个
MethodDeclaration
:int getValue(){ return 42; }
这导致我的实际代码抛出错误,因为看起来好像有两个签名相同的方法。
为什么我没有使用内部方法将枚举作为实际的EnumDeclaration
,而是看起来枚举内部的方法实际上是在外部类本身中声明的?
我不认为这是一个错误,因为eclipse中的AST View可以很好地处理类似的类,但是我无法弄清楚我在做什么错。启用绑定解析无济于事。
解决方法
您需要通过调用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());