为什么枚举常量类体可以定义任意实例字段和方法,但它不能声明静态成员或定义构造函数



James Gosling的Java编程语言中,它指定

"与其他匿名内部类一样,枚举常量类主体可以定义任意实例字段,并且方法,但它不能声明静态成员或定义构造函数。还要注意,因为枚举常量是隐式静态字段,这些匿名内部类没有封闭实例。"

我试着在下面的代码中这样做,并得到错误

"字段pieceType不能声明为静态;静态字段只能声明为静态或顶级类型" (这意味着什么)

package com.example;

enum ChessPiece{
    PAWN{
        @Override
        void pieceName(String name) {
            // TODO Auto-generated method stub
            System.out.println("PAWN");
        }
    },
    ROOK{
        @Override
        void pieceName(String name) {
            // TODO Auto-generated method stub
            System.out.println("ROOK");
        }
    },
    QUEEN{
        static String pieceType = "QUEEN"; // ERROR
        @Override
        void pieceName(String name) {
            // TODO Auto-generated method stub
            System.out.println("QUEEN");
        }
    };
    abstract void pieceName(String name);
}

为什么会这样?

您只能在类中声明静态变量。

好吧,让我们看看这里到底发生了什么。

QUEEN{
    static String pieceType = "QUEEN"; // ERROR
    @Override
    void pieceName(String name) {
        // TODO Auto-generated method stub
        System.out.println("QUEEN");
    }
}

这可能不是很明显,但您已经在这里声明了一个内部类。这必然源于您正在实现一个抽象方法,并且可以很容易地进行验证:

System.out.println(ChessPiece.class == ChessPiece.QUEEN.getClass());

规范指出非static内部类[2]不能声明static成员。我不认为有任何大的理论原因[1],除了在概念上有点奇怪,但事实就是这样

换句话说,你应该在这样的东西上看到同样的错误:

class Foo {
    static final String TOP_LEVEL = "ok";
    static class Bar {
        static final String NESTED_STATIC = "ok";
    }
    class Bar {
        static final String NESTED_NOT_STATIC = "error";
    }
}

[1] 对Java管道有更好理解的人应该可以随意更正这一点。

[2] 我想static和非static内部类之间的区别本身可能有点令人困惑。我建议对此进行调查,并在必要时提出后续问题。

最新更新