Java中枚举的命名:单数还是复数?

问题

是否有关于如何命名Java枚举的"官方"建议?

enum Protocol { HTTP, HTTPS, FTP }

要么

enum Protocols { HTTP, HTTPS, FTP }

我知道在.Net世界中,除了表示位标志的枚举之外,建议使用单数。只是好奇Java中是否有类似的东西。

一个相关的问题似乎是.Net特定的:Singular or plural for enumerations?


#1 热门回答(174 赞)

Java中的枚举(以及可能的枚举)应该是单数的。我们的想法是,你不是选择多个协议,而是选择一个值列表中可能选择的协议。

注意没有复数:http://docs.oracle.com/javase/tutorial/java/javaOO/enum.html


#2 热门回答(16 赞)

就像在数据库中定义表名或在Java中定义表名时一样,使用单数作为枚举时,它也是最佳选择。看看你将如何使用它。

我们来写一个例子:

public enum Day {
SUNDAY, MONDAY, TUESDAY, WEDNESDAY, THURSDAY, FRIDAY, SATURDAY
}

class Appointment {
private Day day;

public void setDay(Day day) {
    this.day = day;
}
}

以单数形式,你可以清楚地看到日属性的意图。 "day"是这个约会即将举行的那一天。否则该方法的签名将是setDay(Days days),并且肯定会有很多人想知道约会是否可能在一天以上发生。

如果你在公司工作,有48小时轮班,你可以尝试定义如下:

public enum Days {
MONDAY_TUESDAY, WEDNESDAY_THURSDAY, FRIDAY_SATURDAY
}

这样你就可以设定你上班的日子。但它仍然看起来很奇怪,有一个更好的选择,并使用单数形式:

public enum Shift {
MONDAY_TUESDAY, WEDNESDAY_THURSDAY, FRIDAY_SATURDAY
}

现在你真的在展示枚举的含义。通常在任何域中,你将发现使用单数作为枚举是最佳选项,因为枚举中的每个常量只是一个元素。

你还提到了.NET。 .NET中的"flags"枚举只是意味着当你期望enum作为参数时,你真正得到的是该枚举的元素列表(存储为整数)。

// Define an Enum with FlagsAttribute.
[FlagsAttribute] 
enum MultiHue : short
{
    Black = 0,
    Red = 1,
    Green = 2,
    Blue = 4
};

public void setMultiHue(MultiHue hues);

你可以在Java中执行相同操作,但枚举仍然是单数:

public enum Hue {
BLACK, RED, GREEN, BLUE;
private final Integer hue;

Hue() {
    this.hue = 1 << this.ordinal();
}

public Integer toFlag() {
    return this.hue;
}
}

public class MultiHue {
private Integer hues = 0;

public void addHue(Hue hue) {
    this.hues |= hue.toFlag();
}

public boolean hasHue(Hue hue) {
    return (this.hues & hue.toFlag()) != 0;
}
}

使用Java更简单,更清晰(尽管使用更多内存)只是使用List。