HashMap

HashMap是Java中的一种线程不安全的Map实现,它以键值对形式存储数据,初始容量为16,加载因子为0.75。在JDK1.8之后,HashMap采用数组+链表+红黑树的数据结构。当链表达到8个节点或数组长度达到64时,会转换为红黑树。HashMap通过哈希算法确定元素位置,允许键的重复但不允许相同的键值对,存储和检索无序。构造方法包括默认构造和指定容量构造。常用方法如values()返回所有值。
摘要由CSDN通过智能技术生成

HashMap

概述

1.位于java.util包需要导包

2.起始版本1.2,替代了Hashtable

3.HashMap是线程不安全的

4.HashMap是Map接口的子类属于双列集合 以键值对(key,value)的形式创建

5.HashMap在jdk1.7前数据结构是数组+链表 在jdk1.8后是数组+链表+红黑树

6.HashMap在创建时会创建一个容量为16的数组,加载因子是0.75(数组长度*0.75),扩容2倍 ,当数组长度大于等于64且链表大于8的时候会触发红黑树.

7.HashMap添加时会根据添加数据的Hash值和数组长度进行寻址算法进行索引添加,如果多个数据添加到通一个索引会进行equals比较内容,如果内容不同将启用链表挂在索引下,内容相同则不添加

8.HashMap底层使用了Hash值进行存储,所以不能存储重复数据,这里不能存储重复数据是指键(key)值(value)可以重复不过会覆盖之前的值

9.不能操作索引,因为存取无序

构造方法

HashMap<String, String> map = new HashMap<>();

常用方法

 HashMap<String, String> map = new HashMap<>();
        map.put("张三","男");
        map.put("李四","男");
        map.put("张三","女");//这里进行了覆盖,所以打印结果为 张三 女
 HashMap<String, String> map = new HashMap<>();
        map.put("张三","男");
        map.put("李四","男");
        map.remove("李四");//删除李四
 HashMap<String, String> map = new Ha
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值