java学习第44天,hashCode

来源:互联网 发布:oracle sql创建表 编辑:程序博客网 时间:2024/05/24 06:16

1,当一个元素存到 hashMap 里面以后 不要修改元素的内容 hashCode 在计算的时候 可能会使用元素的内容 如果修改了元素的内容的话 hashCode 的值可能就会发生改变 会影响元素的遍历

2,hashMap 在刚开始创建的时候 默认有 16 的容量 size() 获取到的是当前实际放在hashMap 里面的元素的个数

3,hashMap 有一个最佳因子 是 0.75 就是当hanhMap 的实际元素的个数 是容量的四分之三的时候 hashMap 的性能会达到最佳 这个时候如果再往里面放元素的话 hashMap 里面的数组会自动扩容 如果要持续很多次地往 hashMap 中 添加元素的话 会导致没添加一个元素就扩容一次 资源耗费会多 最佳实现是先知道总共有多少个元素等待放入 然后提前设置好 hashMap 的容量 然后再添加元素 就会大大降低 扩容的频率