IdentityHashMap使用==比较键,不调用equals和hashCode,基于引用相等性存储对象,适合需精确区分实例的场景,如框架开发或对象追踪。
在Java中,IdentityHashMap 是一个特殊的Map实现,它判断两个键是否相等的标准不是调用 equals() 方法,而是使用 == 运算符比较对象的内存地址。这意味着即使两个对象的内容完全相同,只要它们是不同的实例,就会被视为不同的键。
普通的 HashMap 使用 equals() 和 hashCode() 来判断键的唯一性,而 IdentityHashMap 完全基于引用相等(reference equality)来工作:
k1 == k2(即指向同一内存地址)。equals() 或 hashCode() 方法,避免了重写这些方法带来的影响。这在某些特定场景非常有用,比如需要精确控制对象身份时。
下面代码演示了 HashMap 和 IdentityHashMap 在处理相同内容但不同实例时的区别:
String str1 = new String("key");
String str2 = new String("key");
System.out.println(str1.equals(str2)); // true
System.out.println(str1 == str2); // false
// 使用 HashMap
Map hashMap = new HashMap<>();
hashMap.put(str1
, "value1");
hashMap.put(str2, "value2");
System.out.println(hashMap.size()); // 输出 1,因为 equals 认为 key 相同
// 使用 IdentityHashMap
Map identityMap = new IdentityHashMap<>();
identityMap.put(str1, "value1");
identityMap.put(str2, "value2");
System.out.println(identityMap.size()); // 输出 2,因为 == 判断是不同对象
可以看到,虽然 str1 和 str2 内容一样,但在 IdentityHashMap 中被视为两个独立的键。
IdentityHashMap 适合以下情况:
注意点:
IdentityHashMap 提供了一种基于对象引用而非内容的映射方式。当你真正关心“是不是同一个对象”而不是“是不是相等的对象”时,它是理想选择。正确理解其行为有助于避免误用,也能在复杂系统设计中发挥独特作用。
基本上就这些。用得不多,但关键时刻很关键。