定义方法的枚举实例,正如您的ID 在这里所做的那样,是枚举类的隐式匿名子类的单例。正常的访问规则适用于子类和枚举类之间,因此需要合成访问器才能查看枚举类的私有特性。
Java 语言规范requires enums to work this way:
枚举常量的可选类主体隐式定义了一个匿名类声明(第 15.9.5 节),它扩展了直接封闭的枚举类型。类体由匿名类的常规规则管理...
这当然是它们的实际实施方式。在 JDK 的 javac 中,这发生在 JavacParser::enumeratorDeclaration 第 3344 行附近(在此版本中):
JCClassDecl body = null;
if (token.kind == LBRACE) {
JCModifiers mods1 = F.at(Position.NOPOS).Modifiers(Flags.ENUM | Flags.STATIC);
List<JCTree> defs = classOrInterfaceBody(names.empty, false);
body = toP(F.at(identPos).AnonymousClassDef(mods1, defs));
}
if (args.isEmpty() && body == null)
createPos = identPos;
JCIdent ident = F.at(identPos).Ident(enumName);
JCNewClass create = F.at(createPos).NewClass(null, typeArgs, ident, args, body);
相关位是,如果声明中有一个左大括号(LBRACE),则为匿名类(names.empty)解析一个类体(classOrInterfaceBody(...)),然后就是这样用作实例创建表达式中的类主体 (NewClass(..., body))。如果您愿意,您可以按照 JCNewClass 节点的编译进行操作,但正如它的 javadoc 所做的那样,它可以建模:
* A new(...) operation.
如您所知,带有类主体的new 操作会创建一个匿名类。