HashMap特点和源码刨析&map遍历

特点:
1:存值是无序的
2:键和值都可以为null 但是 键是能是一个为null
3:键的位置是惟一的,底层的数据结构控制键的
4:jdk1.8之前是 链表+数组 jdk1.8之后是链表+数组+红黑树
5:(阀值)>8 并且数组长度大于64,才能将链表转换为黑红树,变成黑红树的目的是为了高效的查询

当对象的hashCode相等时会产生hash碰撞 若key内容相同则替换旧的value,不然就链到表的后方,链表长度超过阀值8就转换为黑红树

&(按位与运算):运算规则:相同二进制位上都是1的时候结果为1 否则为0
^(按位异或运算):运算规则:相同二进制位数上,数字相同结果为0不同为1.

初始化容量初始化 也就是new HashMap()小括号里的值
数量=需要储存数量/负载因子+1 负载因子(0.75)

map便利的几种方法
public static void method1(HashMap<String,String> map) {
Set<Map.Entry<String,String>> entries= map.entrySet();
for(Iterator<Map.Entry<String,String>> it= entries.iterator();it.hasNext()😉{
Map.Entry<String,String> its= it.next();
System.out.println(its.getKey()+"–"+its.getKey());
}
}
public static void method3(HashMap<String,String> map) {
map.forEach((key,value)->{
System.out.println(key+"====="+value);
});
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值