我们知道枚举数天生就是有值的,默认是从0开始,那么我们需要从1开始怎么办呢?可以这么写
public enum Ensemble {
SOLO, DUET, TRIO, QUARTET, QUINTET, SEXTET, SEPTET, OCTET, NONET, DECTET;
public int numberOfMusicians() {
return ordinal()+1;
}
}
所有枚举都有一个ordinal方法用来返回序号。这个枚举看起来不错,但是维护起来很麻烦,一旦常量重新排序numberOfMusicians方法就被破坏了。
其实我们有一个更好的办法来解决这个问题:
public enum Ensemble {
SOLO(1), DUET(2), TRIO(3), QUARTET(4), QUINTET(5), SEXTET(6), SEPTET(7), OCTET(8),
DOUBLE_QUARTET(8), NONET(9), DECTET(10), TRIPLE_QUARTET(12);
private final int numberOfMusicians;
Ensemble(int size) {
this.numberOfMusicians = size;
}
public int numberOfMusicians() {
return numberOfMusicians;
}
}
这种方式能够任意定义枚举的值,顺序重排也不会有任何影响,实在是再好不过了。