• Java Map集合面试题汇总


    1、 你都知道哪些常用的Map集合
    HashMap、HashTable、LinkedHashMap、ConcurrentHashMap。

    2、Collection集合接口和Map接口有什么关系?
    没关系,Collection是List、Set父接口不是Map父接口。

    3、HashMap是线程安全的吗?线程安全的Map都有哪些?性能最好的是哪个?
    HashMap不是线程安全的。线程安全的有HashTable、ConcurrentHashMap、SynchronizedMap,性能最好的是ConcurrentHashMap。

    4、使用HashMap有什么性能问题吗?
    使用HashMap要注意避免集合的扩容,它会很耗性能,根据元素的数量给它一个初始大小的值。

    5、HashMap的数据结构是怎样的?默认大小是多少?内部是怎么扩容的?
    HashMap是数组和链表组成的,默认大小为16,当hashmap中的元素个数超过数组大小*loadFactor(默认值为0.75)时就会把数组的大小扩展为原来的两倍大小,然后重新计算每个元素在数组中的位置。

    6、怎么按添加顺序存储元素?怎么按A-Z自然顺序存储元素?怎么自定义排序?
    按添加顺序使用LinkedHashMap,按自然顺序使用TreeMap,自定义排序TreeMap(Comparetor c)。

    7、HashMap的链表结构设计是用来解决什么问题的?
    HashMap的链表结构设计是用来解决key的hash冲突问题的。

    8、HashMap的键、值可以为NULL吗?HashTable呢?
    HashMap的键值都可以为NULL,HashTable不行。

    9、HashMap使用对象作为key,如果hashcode相同会怎么处理?
    key的hash冲突,如果key equals一致将会覆盖值,不一致就会将值存储在key对应的链表中。

    10、HashMap中的get操作是什么原理?
    先根据key的hashcode值找到对应的链表,再循环链表,根据key的hash是否相同且key的==或者equals比较操作找到对应的值。

    转载自:https://www.jianshu.com/p/3dfabb977bf6
    作者:嘻哈辣
    来源:简书

  • 相关阅读:
    Flutter插件之阿里百川
    2022秋招,Java框架最全面试攻略,吃透32个必问题直接速通大厂
    【Redis】SSM整合Redis&注解式缓存的使用
    开源物联网平台ThingsBoard的安装
    统计学习方法 隐马尔可夫模型
    如何编写一份完整的软件测试报告?
    docker中简单安装redis
    【Github】 Github修改仓库的基本信息
    C++11新特性
    学习亚马逊云科技AWS云计算技术的三款官方免费3A游戏大作
  • 原文地址:https://blog.csdn.net/m0_67403272/article/details/126387234