У меня есть несколько перечислений Java, которые выглядят как-то вроде ниже (отредактированы для обеспечения конфиденциальности и т. Д.). В каждом случае у меня есть метод поиска, который я действительно не удовлетворен; в приведенном ниже примере это findByChannelCode
.Правильный способ поиска перечисления по значению
public enum PresentationChannel {
ChannelA("A"),
ChannelB("B"),
ChannelC("C"),
ChannelD("D"),
ChannelE("E");
private String channelCode;
PresentationChannel(String channelCode) {
this.channelCode = channelCode;
}
public String getChannelCode() {
return this.channelCode;
}
public PresentationChannel findByChannelCode(String channelCode) {
if (channelCode != null) {
for (PresentationChannel presentationChannel : PresentationChannel.values()) {
if (channelCode.equals(presentationChannel.getChannelCode())) {
return presentationChannel;
}
}
}
return null;
}
}
Проблема заключается в том, я чувствую себя глупо делать эту линейную Lookups, когда я мог бы просто использовать в HashMap<String, PresentationChannel>
. Поэтому я подумал о решении ниже, но это немного грязнее, что я надеюсь, и, более того, я не хотел изобретать колесо, когда кто-то еще сталкивался с этим. Я хотел получить часть мудрости мудреца этой группы: Каков правильный способ индексирования перечисления по значению?
Мое решение:
ImmutableMap<String, PresentationChannel> enumMap = Maps.uniqueIndex(ImmutableList.copyOf(PresentationChannel.values()), new Function<PresentationChannel, String>() {
public String apply(PresentationChannel input) {
return input.getChannelCode();
}});
и, в перечислении:
public static PresentationChannel findByChannelCode(String channelCode) {
return enumMap.get(channelCode);
}
вы понимаете, что EnumMap карта enum-> Объект не вице-стиха? – bestsss
Профилирование кода показывает, что линейный поиск неадекватен? – trashgod
@ bestsss, возможно, моя карта плохо названа. Это не EnumMap, просто карта из String-> PresentationChannel (то есть value-> instance) – Ray