java map 面试题
时间: 2023-08-06 22:08:54 浏览: 210
回答: 在Java的Map面试中,常常会被问到关于Map的一些问题。首先,HashMap不是线程安全的,而线程安全的Map有HashTable、ConcurrentHashMap和SynchronizedMap,其中性能最好的是ConcurrentHashMap。\[1\]在单列集合中,List和Set的区别是List集合元素有序并且可以重复,而Set集合元素无序并且不允许重复。\[2\]在ArrayList和LinkedList的区别方面,ArrayList底层数据结构为数组,所以查询速度较快但增删速度较慢,而LinkedList底层数据结构为双向链表,所以查询速度较慢但增删速度较快。\[2\]对于HashMap的数据结构,JDK1.7版本是由数组和链表组成,JDK1.8版本之后还加入了二叉树。HashMap的put方法会根据key的hash地址将数据存放到对应的索引位置,如果存在冲突则会使用链表或二叉树来解决。\[2\]按添加顺序存储元素可以使用LinkedHashMap,按自然顺序存储元素可以使用TreeMap,而自定义排序可以使用TreeMap并传入Comparator。\[3\]
#### 引用[.reference_title]
- *1* *3* [Java Map集合面试题汇总](https://blog.csdn.net/m0_67403272/article/details/126387234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [Map集合常见面试题](https://blog.csdn.net/weixin_42362271/article/details/86568914)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
阅读全文