EnumMap和HashMap的区别
EnumMap和HashMap都是实现Map接口的类。但是它们之间存在着一些差异。所以我们试着列出EnumMap和HashMap之间的区别。
EnumMap
EnumMap是Map接口的一个专门实现,用于枚举类型。它扩展了AbstractMap并实现了Java中的Map接口。EnumMap的几个要点如下:
- EnumMap类是Java集合框架的一个成员,它不是同步的。
- EnumMap是一个有序的集合,它们按照键的自然顺序被维护(键的自然顺序是指枚举常量在枚举类型中被声明的顺序)。
- EnumMap比HashMap快得多。
- 每个EnumMap实例的所有键必须是相同枚举类型的键。
- EnumMap不允许插入空键,如果我们试图插入空键,它将抛出NullPointerException。
- EnumMap内部表示为数组,因此它提供了更好的性能。
EnumMap示例代码:
import java.util.*;
class EnumMapExample {
public enum Days {
Sunday,
Monday,
Tuesday,
Wendnesday,
Friday;
}
public static void main(String[] args)
{
// Creating an EnumMap of the Days enum
EnumMap<Days, Integer> enumMap
= new EnumMap<>(Days.class);
// Insert using put() method
enumMap.put(Days.Sunday, 1);
enumMap.put(Days.Monday, 2);
enumMap.put(Days.Tuesday, 3);
enumMap.put(Days.Wednesday, 4);
enumMap.put(Days.Friday, 5);
// Printing size of EnumMap
System.out.println("Size of EnumMap: " + enumMap.size());
// Printing the EnumMap
for (Map.Entry m : enumMap.entrySet()) {
System.out.println(m.getKey() + " => " + m.getValue());
}
}
}
运行结果:
Size of EnumMap: 5
Sunday => 1
Monday => 2
Tuesday => 3
Wendensday => 4
Friday => 5
HashMap
HashMap是一个实现了Map接口的类。它在键和值对中存储数据,其中的键应该是唯一的。如果你试图插入重复的键,它将替换相应键的元素。它允许存储空键和空值,但只应该有一个空键和多个空值。Java HashMap与HashTable类似,但它是同步的。HashMap并不保持顺序,这意味着它不保证元素的任何特定顺序。
HashMap示例代码:
import java.util.*;
public class YiibaiDemo {
public static void main(String[] args)
{
// Create an empty hash map
HashMap<Integer, String> map = new HashMap<>();
// Adding elements to the map
map.put(11, "Yiibai");
map.put(22, "Andy");
map.put(33, "Vsdiffer");
// Printing size of the map
System.out.println("Size of map is: " + map.size());
// Iterating the map
for (Map.Entry m : map.entrySet()) {
System.out.println(m.getKey() + " => " + m.getValue());
}
}
}
运行结果:
Size of map is: 3
22 => Andy
11 => Yiibai
33 => Vsdiffer
EnumMap和HashMap的区别
EnumMap | HashMap |
---|---|
EnumMap是一种专门的地图实现,只使用Enum类型的键。 | 在HashMap中,可以使用Enum,也可以使用任何其他对象作为键。 |
EnumMap不允许存储空键。 | HashMap允许存储空键和空值,但是只能有一个空键对象,可以有任意数量的空值。 |
EnumMap内部使用数组 | HashMap内部使用HashTable。 |
EnumMap是一个专门的地图实现,只使用枚举类型的键。由于这个原因,EnumMap的性能比HashMap好。 | 与EnumMap相比,HashMap的性能略低。 |
EnumMap按照键的自然顺序(枚举常量的声明顺序)来存储键。 | 在HashMap中,不对键进行排序。 |
由于EnumMap内部使用数组,并使用 ordinal() 以其自然顺序存储键,所以不存在碰撞的可能性。 |
HashMap使用 hashCode() 来存储键和值,所以有碰撞的可能性。 |