1

我正在尝试使用枚举创建层次结构类型系统。我以前从未使用过枚举。

此方法始终返回 Peasant。我认为这是因为我错误地使用了“this”,或者我完全误解了枚举。

public enum Rank {
    PEASANT,
    TRADER,
    SQUIRE,
    MERCHANT,
    KNIGHT,
    NOBLE,
    KING;

    public Rank getNextRank() {
        switch (this) {
        case PEASANT:
            return SQUIRE;
        case SQUIRE:
            return KNIGHT;
        case KNIGHT:
            return NOBLE;
        case NOBLE:
            return KING;
        case KING:
            return PEASANT;
        }
        return PEASANT;
    }
}

(我意识到 KING 案例不是必需的,但我喜欢它的可读性)

我想Rank.PEASANT.getNextRank()返回Rank.SQUIRERank.NOBLE.getNextRank()返回Rank.KING等。

4

2 回答 2

3

那么该代码应该可以工作,但我个人只是使​​用ordinal()

public Rank getNextRank() {
    Rank[] allRanks = Rank.values();
    return allRanks[(ordinal() + 1) % allRanks.length];
}

如果在枚举中使用静态 final 字段,则可以避免调用Rank.values()(在每次调用时创建一个新数组),该字段在Rank.values()静态初始化程序块中设置为。

如果您可以将“下一个等级”传递给枚举构造函数并将其存储为一个字段,那就太好了,但是在这种情况下这不起作用,因为您每次都有效地使用前向引用。当然,您可以有一个非最终字段,并在静态初始化程序中设置值:

public enum Rank {
    PEASANT,
    TRADER,
    SQUIRE,
    MERCHANT,
    KNIGHT,
    NOBLE,
    KING,

    private Rank next;

    static {
        PEASANT.next = TRADER;
        TRADER.next = SQUIRE;
        SQUIRE.next = MERCHANT;
        MERCHANT.next = KNIGHT;
        NOBLE.next = KING;
        KING.next = PEASANT;
    }

    public Rank getNextRank() {
        return next;
    }
}

这将更加灵活,例如,如果您想要两个“相等”的排名,它们都具有相同的“下一个”排名。

于 2013-06-29T06:25:38.120 回答
1

我无法在评论中传达它工作正常。请看图片。

再次检查流程。问题出在其他地方。

System.out.println(Rank.SQUIRE.getNextRank());  //printed KNIGHT

在此处输入图像描述

于 2013-06-29T06:32:31.103 回答