hashmap面试题简书_java面试问答题

hashmap面试题简书_java面试问答题JAVA中的HashMap面试题整理JDK1.7版本,HashMap的数据结构是什么?数组+单向链表什么叫做Hash桶数组中的单向链表HashMap的数组长度为什么必须是2的幂?计算元素存在数组中下标的算法:hash值&数组长度-1如果数组长度不是2的幂,减1后二进制的某一位有可能出现0,导致数组某个位置永远存不到数据HashMap的默认负载因子是多少,作用是什么?默认负载因子是0.75作用:数组长度*负载因子=阈值(扩容条件)HashMap的默认负载因子为什么是0.75

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

JAVA中的HashMap面试题整理

  1. JDK1.7版本,HashMap的数据结构是什么?
    数组+单向链表
  2. 什么叫做Hash桶
    数组中的单向链表
  3. HashMap的数组长度为什么必须是2的幂?
    计算元素存在数组中下标的算法:hash值 & 数组长度-1
    如果数组长度不是2的幂,减1后二进制的某一位有可能出现0,导致数组某个位置永远存不到数据
  4. HashMap的默认负载因子是多少,作用是什么?
    默认负载因子是0.75
    作用:数组长度*负载因子=阈值(扩容条件)
  5. HashMap的默认负载因子为什么是0.75?
    取得了时间和空间的平衡
    假设负载因子过大,导致数组装满后才扩容,牺牲时间,利用空间
    假设负载因子过小,导致数组装载较少内容就扩容,牺牲空间,利用时间
  6. HashMax数组最大长度是多少?
    1 << 30
  7. HashMap数组最大长度为什么是1 << 30?
    因为数组长度必须是2的幂并且HashMap数组最大长度的变量为int类型,所有1<<30
  8. 什么叫做Hash碰撞/冲突?
    两个对象的hash值一样,导致在数组中的下标一样
  9. HashMap何时扩容?
    元素个数>=阈值,并且存入数据的位置不等于null
  10. HashMap扩容机制是什么?
    原来的2倍
  11. HashMap存入null键的位置?
    hash数组下标为0的位置
  12. 什么叫做Hash回环?
    多线程下会出现Hash回环
    线程1:不断添加数据,导致不断扩容
    线程2:不断遍历
    出现Hash回环,活该,HashMap明确说明该集合不是个线程安全的集合,多线程下应该使用ConcurrentHashMap
  13. JDK1.7版本和JDK1.8版本的HashMap的区别
    JDK1.7:数组+链表,头插法,通过散列算法获取hash值
    JDK1.8:数组+链表+红黑树,尾插法,通过低16位^高16位让hash值更加散列
  14. JDK1.8版本HashMap为什么添加红黑树的数据结构?
    因为链表查询慢,红黑树查询快
  15. JDK1.8版本什么时候由数组+链表变成数组+红黑树
    链表长度>8并且数组长度>64时,从数组+链表变成数组+红黑树
  16. JDK1.8版本为什么链表长度大于8时,变成数组+红黑树
    因为泊松部分(统计概率学),当红黑树里的数据小于6时,又会将数组+红黑树变会数组+链表
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169550.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月10日 下午11:36
下一篇 2022年8月10日 下午11:36


相关推荐

  • servlet到底是什么[通俗易懂]

    servlet到底是什么[通俗易懂]servlet到底是什么?对于这个问题一直云里雾里的,今天打算刨根问底。一、Servlet简介  Servlet是sun公司提供的一门用于开发动态web资源的技术。  Sun公司在其API中提供了一个servlet接口,用户若想用发一个动态web资源(即开发一个Java程序向浏览器输出数据),需要完成以下2个步骤:  1、编写一个Java类,实现servlet接口。  2、把开发好的Java类部署…

    2022年6月15日
    50
  • MySql数据库约束

    关系型数据库系统和文件系统的一个不同点是,关系数据库本身能保证存储数据的完整性,不需要应用程序的控制,而文件系统一般需要在程序端进行控制。当前几乎所有的关系型数据库都提供了约束(constraits)

    2021年12月28日
    44
  • linux的linux-aarch64和 linux-x86_64「建议收藏」

    linux的linux-aarch64和 linux-x86_64「建议收藏」在下载linuxtar包的时候可以看到有下面两种tar包。。。。。。。。什么意思呢?linux-aarch64.tar.gzlinux-x86_64.tar.gz是指服务器内核版本使用命令$arch即可查看自己linux的内核版本。正常情况下下载x86的就可以这个说是cpu架构https://blog.csdn.net/rd_w_csdn/article/details/53841018这个说是交叉编译工具链应该也是提供一个aarch64内核…

    2022年10月17日
    4
  • java软件工程师和java开发工程师区别_软件测试工程师

    java软件工程师和java开发工程师区别_软件测试工程师有很多朋友只知道“软件工程师”这个五个字是一个职业,并不清楚这个职业具体的诸多事情,而对于“java工程师”这个职业应该就更为陌生了。其实因为这个充满网络和数据的信息时代,人们对这种新兴的职业已经不是那么陌生了,甚至因为良好的发展态势和不错的薪资待遇吸引来了很多的人,想要学习java和软件技术并进而从事这两个职位。今天就来和大家科普一下java工程师和软件工程师的关系是什么,二者各自具体的工作性质和岗位职责是什么,帮有想了解java工程师和软件工程师的朋友们解答疑惑,能更好的认识这两个职位。首先来说软件工

    2026年2月20日
    6
  • catalan数

    catalan数原理令 h 0 1 h 1 1 catalan 数满足递推式 h n h 0 h n 1 h 1 h n 2 h n 1 h 0 n 2 例如 h 2 h 0 h 1 h 1 h 0 1 1 1 1 2h 3 h 0 h 2 h 1 h 1 h 2 h 0 1 2 1 1 2 1 5 另类递推式

    2026年3月19日
    1
  • 讯飞举办“星火快答”生态沙龙,共探交互智能体赋能数字孪生新路径

    讯飞举办“星火快答”生态沙龙,共探交互智能体赋能数字孪生新路径

    2026年3月14日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号