Java高级Day23-HashMap

74.HashMap

  1. Map接口常用实现类:HashMap、Hashtable和Properties

  2. HashMap是Map接口使用频率最高的实现类

  3. HashMap是以key-value对的方式来存储数据

  4. key不能重复,但是值可以重复,允许使用null健和null值

  5. 如果添加相同的key,会覆盖原来的key

  6. 与HashSet一样,不保证映射的顺序,因为底层是以hash表的方式来存储的

  7. HashMap没有实现同步,因此线程是不安全的,方法没有做同步互斥的操作,没有synchronized

HashMap底层扩容机制:

  1. HashMap底层维护了Nod类型的数组table,默认为null

  2. 当创建对象时,将加载因子(loadfactor)初始化为0.75

  3. 当添加key-val时,通过key的哈希值得到在table的索引。然后判断该索引处是否有元素,如果没有元素直接添加。如果该索引处有元素,继续判断该元素的key是否和准入加入的key相等,如果相等,直接替换val;如果不相等需要判断是树结构还是链表结构,做出相应处理。如果添加时发现容量不够,需要扩容

  4. 第1次添加,则需要扩容table容量为16,临界值为12

  5. 以后再扩容,则需要扩容table为原来的2倍,临界值为原来的2倍,既24,以此类推

模拟HashMap触发扩容,树化情况

复制代码
public class HelloJava {
    public static void main(String[] args) {
        HashMap hashMap = new HashMap();
        for (int i = 1;i <= 12;i++){
            hashMap.put(new A(i),"hello");
        }
        hashMap.put("aaa","bbb");
        System.out.println("hashMap=" + hashMap);
    }
}
​
class A{
    private int num;
​
    public A(int num) {
        this.num = num;
    }
    //所有的A对象的HashCode都是100
    @Override
    public int hashCode() {
        return 100;
    }
​
    @Override
    public String toString() {
        return "A{" +
                "num=" + num +
                '}';
    }
}
相关推荐
好学且牛逼的马3 分钟前
MyBatis-Plus的深度解析
java
苏纪云5 分钟前
数据结构<C++>——数组
java·数据结构·c++·数组·动态数组
Evand J19 分钟前
【MATLAB例程】二维环境定位,GDOP和CRLB的计算,锚点数=4的情况(附代码下载链接)
开发语言·matlab·定位·toa·crlb·gdop
郝学胜-神的一滴26 分钟前
使用现代C++构建高效日志系统的分步指南
服务器·开发语言·c++·程序人生·个人开发
典则26 分钟前
STM32FreeRtos入门(五)——同步互斥与通信
java·jvm·stm32
你不是我我27 分钟前
【Java 开发日记】我们来讲一讲阻塞队列及其应用
java·开发语言
互联网中的一颗神经元29 分钟前
小白python入门 - 9. Python 列表2 ——从基础操作到高级应用
java·开发语言·python
大厂码农老A32 分钟前
我带的外包兄弟放弃大厂转正,薪资翻倍入职字节
java·后端·面试
wjs202433 分钟前
PHP 表单:深入浅出地掌握表单处理
开发语言
摇滚侠41 分钟前
Spring Boot3零基础教程,生命周期监听,自定义监听器,笔记59
java·开发语言·spring boot·笔记