Если кодовая база приложения будет использовать много перечислений, то я бы предпочел следующее решение, которое я использовал в своем приложении.
Базовый класс
public class Enum {
protected int _enumValue;
protected Enum(int enumValue) {
this._enumValue = enumValue;
}
public int Value() {
return this._enumValue;
}
}
Ваши перечисления будут затем следовать этой схеме
Actual Enum
public class DATE_FORMAT extends Enum {
public static final int DDMMYYYY = 1;
public static final int MMDDYYYY = 2;
public static final int YYYYMMDD = 3;
public DATE_FORMAT(int enumValue) {
super(enumValue);
}
}
И ваш код может использовать это перечисление следующим образом
String getFormattedDate(DATE_FORMAT format) {
String sDateFormatted = "";
switch (format.Value()) {
case DATE_FORMAT.DDMMYYYY :
break;
case DATE_FORMAT.MMDDYYYY :
break;
case DATE_FORMAT.YYYYMMDD :
break;
default:
break;
}
return sDateFormatted;
}
Абонент может использовать функцию как
void callerAPI() {
DATE_FORMAT format = new DATE_FORMAT(DATE_FORMAT.DDMMYYYY);
String sFormattedDate = getFormattedDate(format);
}
Это еще не полное доказательство против инициализации производных объектов Enum с любым целочисленным значением. Тем не менее, он может обеспечить хорошее синтаксическое руководство для работы в non-enum среде.