Я использую перечисление, чтобы сделать несколько констант:
enum ids {OPEN, CLOSE};
значение OPEN равно нулю, но я хочу, чтобы оно равнялось 100. Возможно ли это?
enum ids {OPEN = 100, CLOSE};
?
Я использую перечисление, чтобы сделать несколько констант:
enum ids {OPEN, CLOSE};
значение OPEN равно нулю, но я хочу, чтобы оно равнялось 100. Возможно ли это?
enum ids {OPEN = 100, CLOSE};
?
Ответы:
Перечисления Java не похожи на перечисления C или C ++, которые на самом деле являются просто метками для целых чисел.
Перечисления Java реализованы больше как классы - и они могут даже иметь несколько атрибутов.
public enum Ids {
OPEN(100), CLOSE(200);
private final int id;
Ids(int id) { this.id = id; }
public int getValue() { return id; }
}
Большая разница в том, что они безопасны от типов что означает, что вам не нужно беспокоиться о назначении перечисления COLOR для переменной SIZE.
См. Http://docs.oracle.com/javase/tutorial/java/javaOO/enum.html для получения дополнительной информации.
enum class
.
Да. Вы можете передать числовые значения в конструктор для перечисления, например так:
enum Ids {
OPEN(100),
CLOSE(200);
private int value;
private Ids(int value) {
this.value = value;
}
public int getValue() {
return value;
}
}
Смотрите Sun Java Language Guide для получения дополнительной информации.
value
(скажем) нулем. Затем включите (скажем) DANCE
в список значений.
как насчет использования этого способа:
public enum HL_COLORS{
YELLOW,
ORANGE;
public int getColorValue() {
switch (this) {
case YELLOW:
return 0xffffff00;
case ORANGE:
return 0xffffa500;
default://YELLOW
return 0xffffff00;
}
}
}
есть только один метод ..
Вы можете использовать статический метод и передать Enum в качестве параметра, например:
public enum HL_COLORS{
YELLOW,
ORANGE;
public static int getColorValue(HL_COLORS hl) {
switch (hl) {
case YELLOW:
return 0xffffff00;
case ORANGE:
return 0xffffa500;
default://YELLOW
return 0xffffff00;
}
}
Обратите внимание, что эти два способа используют меньше памяти и больше единиц обработки. Я не говорю, что это лучший способ, но это просто другой подход.
getColorValue()
синхронизируется во втором примере?
HL_COLORS.getColorValue(HL_COLORS.YELLOW);
без инициализации enum.
Если вы используете очень большие типы enum, то может быть полезно следующее;
public enum deneme {
UPDATE, UPDATE_FAILED;
private static Map<Integer, deneme> ss = new TreeMap<Integer,deneme>();
private static final int START_VALUE = 100;
private int value;
static {
for(int i=0;i<values().length;i++)
{
values()[i].value = START_VALUE + i;
ss.put(values()[i].value, values()[i]);
}
}
public static deneme fromInt(int i) {
return ss.get(i);
}
public int value() {
return value;
}
}
Если вы хотите эмулировать перечисление C / C ++ (базовые числа и инкременты nexts):
enum ids {
OPEN, CLOSE;
//
private static final int BASE_ORDINAL = 100;
public int getCode() {
return ordinal() + BASE_ORDINAL;
}
};
public class TestEnum {
public static void main (String... args){
for (ids i : new ids[] { ids.OPEN, ids.CLOSE }) {
System.out.println(i.toString() + " " +
i.ordinal() + " " +
i.getCode());
}
}
}
OPEN 0 100 CLOSE 1 101
Функция ordinal () возвращает относительную позицию идентификатора в перечислении. Вы можете использовать это для получения автоматической индексации со смещением, как с перечислением в стиле C.
Пример:
public class TestEnum {
enum ids {
OPEN,
CLOSE,
OTHER;
public final int value = 100 + ordinal();
};
public static void main(String arg[]) {
System.out.println("OPEN: " + ids.OPEN.value);
System.out.println("CLOSE: " + ids.CLOSE.value);
System.out.println("OTHER: " + ids.OTHER.value);
}
};
Дает вывод:
OPEN: 100
CLOSE: 101
OTHER: 102
Редактировать: только что понял, что это очень похоже на ответ ggrandes , но я оставлю его здесь, потому что он очень чистый и как можно ближе к перечислению в стиле C.
@scottf
Перечисление похоже на синглтон. JVM создает экземпляр.
Если бы вы создали его самостоятельно с помощью классов, это могло бы выглядеть так
public static class MyEnum {
final public static MyEnum ONE;
final public static MyEnum TWO;
static {
ONE = new MyEnum("1");
TWO = new MyEnum("2");
}
final String enumValue;
private MyEnum(String value){
enumValue = value;
}
@Override
public String toString(){
return enumValue;
}
}
И может быть использовано так:
public class HelloWorld{
public static class MyEnum {
final public static MyEnum ONE;
final public static MyEnum TWO;
static {
ONE = new MyEnum("1");
TWO = new MyEnum("2");
}
final String enumValue;
private MyEnum(String value){
enumValue = value;
}
@Override
public String toString(){
return enumValue;
}
}
public static void main(String []args){
System.out.println(MyEnum.ONE);
System.out.println(MyEnum.TWO);
System.out.println(MyEnum.ONE == MyEnum.ONE);
System.out.println("Hello World");
}
}
public class MyClass {
public static void main(String args[]) {
Ids id1 = Ids.OPEN;
System.out.println(id1.getValue());
}
}
enum Ids {
OPEN(100), CLOSE(200);
private final int id;
Ids(int id) { this.id = id; }
public int getValue() { return id; }
}
@scottf, вы, вероятно, запутались из-за конструктора, определенного в ENUM.
Позвольте мне объяснить это.
Когда class loader
загружается enum
класс, enum
вызывается также конструктор. На что!! Да, это называется OPEN
и close
. С какими ценностями 100
для OPEN
и 200
дляclose
Могу ли я иметь другое значение?
Да,
public class MyClass {
public static void main(String args[]) {
Ids id1 = Ids.OPEN;
id1.setValue(2);
System.out.println(id1.getValue());
}
}
enum Ids {
OPEN(100), CLOSE(200);
private int id;
Ids(int id) { this.id = id; }
public int getValue() { return id; }
public void setValue(int value) { id = value; }
}
Но это плохая практика. enum
используется для представления constants
как days of week
, colors in rainbow
то есть такой небольшой группы предопределенных констант.
Я думаю, вы смущены, глядя на счетчики C ++. Перечислители Java разные.
Это будет код, если вы привыкли к перечислениям C / C ++:
public class TestEnum {
enum ids {
OPEN,
CLOSE,
OTHER;
public final int value = 100 + ordinal();
};
public static void main(String arg[]) {
System.out.println("OPEN: " + ids.OPEN.value);
System.out.println("CLOSE: " + ids.CLOSE.value);
System.out.println("OTHER: " + ids.OTHER.value);
}
};