【发布时间】:2011-02-03 13:54:53
【问题描述】:
我有几个 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;
}
}
问题是,当我可以使用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->Object 不是反之亦然吗?
-
代码分析是否显示线性查找不足?
-
@bestsss,也许我的地图名字不好。它不是 EnumMap,只是来自 String->PresentationChannel 的映射(即 value->instance)
-
@trashgod,在这里的例子中,为了清楚起见,只有几个例子。在实际代码中,这种习语的例子还不少,而且查找次数也很多。
-
如果您不需要自定义但通用的解决方案...我编辑答案让您退出,基本上您需要一个外部存储库和一个接口来实现。