gpt4 book ai didi

java - 如果查找键是字符串,则 EnumMap 或 HashMap

转载 作者:IT老高 更新时间:2023-10-28 21:09:09 29 4
gpt4 key购买 nike

我试图权衡使用 EnumMap 而不是 HashMap 的利弊。因为,我将一直使用 String 进行查找,看来带有 String 键的 HashMap 将是正确的选择。但是,EnumMap 似乎是更好的设计,因为它传达了我将键限制为特定枚举的意图。想法?

这是一个虚构的例子,展示了我将如何使用 Map:

enum AnimalType { CAT, DOG }
interface Animal {}
class Cat implements Animal {}
class Dog implements Animal {}

public class AnimalFactory {

private static final Map<AnimalType, Animal> enumMap
= new EnumMap<AnimalType, Animal>(AnimalType.class);
// versus
private static final Map<String, Animal> stringMap
= new HashMap<String, Animal>();

static {
enumMap.put(AnimalType.CAT, new Cat());
enumMap.put(AnimalType.DOG, new Dog());
stringMap.put("CAT", new Cat());
stringMap.put("DOG", new Dog());
}
public static Animal create(String type) {
Animal result = enumMap.get(AnimalType.valueOf(type));
Animal result2 = stringMap.get(type);
return result;
}
}

假设 AnimalType 枚举和 map 将仅由 AnimalFactory 用于创建动物,而不能用于其他任何地方。

我应该使用哪个 map

最佳答案

如果可以枚举所有有效键,我会使用它,因为它可以确保您始终使用有效值。

它还可以避免混淆,因为 String 可以用于很多事情,并且很容易将“Animal”字符串转换为用于其他用途的字符串。由于枚举类型通常不能与其他类型互换(除非您使用通用接口(interface)),因此编码出错的可能性较小。

关于java - 如果查找键是字符串,则 EnumMap 或 HashMap,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10445274/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com