<分区>
对于 HashMap<String, String> map
每次将键值对插入到映射中时,都会计算一个哈希 -
java.lang.String#hashCode
public int hashCode() {
int h = hash;
if (h == 0 && value.length > 0) {
char val[] = value;
for (int i = 0; i < value.length; i++) {
h = 31 * h + val[i];
}
hash = h;
}
return h;
}
因为它是不言自明的,所以 put 操作的复杂性基本上就是哈希计算的复杂性。
那么什么才是定义 hashmap 最坏情况下 put/get 操作时间复杂度的合适方法呢?
如果你从哈希冲突的角度有同样的问题,你可以在这里找到答案: Is a Java hashmap really O(1)?