java - HashMap 实现,允许覆盖 hash 和 equals 方法

标签 java hashmap

在 Java 中,您可以覆盖 HashMap 的键对象的 equals 和 hash 方法,以确定如何生成哈希码以及何时应将两个键对象视为相等。

是否有任何 Map 实现允许通过覆盖其哈希方法(并通过可覆盖的 equals(key1,key2) 方法确定键相等性)在 Map 类中定义哈希和等于?

用例:

假设我们有一个 GeoData 类的对象,包含以下字段:国家、地区、城市。我们要访问两个 map :map x 存储每个区域的居民数量,而 map y 存储每个区域的居民数量每个城市的居民。

要获取 GeoData 对象的两种信息,我们首先需要从该对象中提取国家和地区,然后创建一个 X 类的新对象,该对象定义了散列并等于考虑国家和地区,并将其用作 map 的键 x。此外,我们需要对国家、地区和城市做同样的事情。创建一个新的 Y 类对象并使用它从 map y 获取值。

如果我们为这些 map xy 中的每一个扩展一个 Map 实现会不会更容易> 并覆盖 hash(GeoData key) 和 equals(GeoData key1,GeoData key2) 方法,这样也可以避免为每次访问创建新的 key 对象?

hash(GeoData key) 然后可以使用 map x 中的国家和地区,或者 map y 用于哈希码计算。

更新:

正确标记为重复。 This回答建议 apache commons-collections AbstractHashMap 是我一直在寻找的。

最佳答案

如果我没理解错的话,你想在不同的 GeoData 中使用具有不同相等标准的相同 key 类型 ( Map )

如果不使用 HashMap,您可以这样做你使用 TreeMap并传递一个不同的 Comparator<GeoData>每个 TreeMap构造函数(一个将通过比较国家、地区和城市来比较两个 GeoData 实例,另一个将只比较国家和地区)。

关于java - HashMap 实现,允许覆盖 hash 和 equals 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41461515/

相关文章:

java - 这个 NullPointerException 的来源是什么

java - 无法通过 Netty 从服务器向客户端发送消息

java - Wicket 请求映射

performance - Unordered_Map查找时间

rust - 为什么entry需要key的所有权?

java - 为什么java中静态成员的顺序很重要?

java - 如何在jsp中填充java对象值

java - org.simpleframework.xml.ElementMap 的正确用法?

java - 在并行流中的 hashmap 中插入值时的线程安全

Java HashMap 覆盖以前的值