【29期】Java集合框架 10 连问,你有被问过吗?
HashMap和HashTable的区别?
说一下 HashMap 的底层结构?
为什么HashMap是线程不安全的
ArrayList 和 LinkedList 的区别是什么?
ArrayList 和 Vector 的区别是什么?
Array 和 ArrayList 有何区别?
说一下 HashSet 的实现原理?
如何决定使用 HashMap 还是 TreeMap?
List、Set、Map 之间的区别是什么?
HashMap怎样解决hash冲突
1.HashMap和HashTable的区别?
HashMap允许将 null 作为一个 entry 的 key 或者 value,而 Hashtable 不允许。
HashMap 把 Hashtable 的 contains 方法去掉了,改成 containsValue 和 containsKey。因为 contains 方法容易让人引起误解。
HashTable 继承自 Dictionary 类,而 HashMap 是 Java1.2 引进的 Map interface 的一个实现。
HashTable 的方法是 Synchronize 的,而 HashMap 不是,在多个线程访问 Hashtable 时,不需要自己为它的方法实现同步,而 HashMap 就必须为之提供外同步。
2.说一下 HashMap 的底层结构?
3.为什么HashMap是线程不安全的
4.ArrayList 和 LinkedList 的区别是什么?
ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。
对于随机访问get和set,ArrayList觉得优于LinkedList,因为LinkedList要移动指针。
对于新增和删除操作add和remove,LinedList比较占优势,因为ArrayList要移动数据。
5.ArrayList 和 Vector 的区别是什么?
PS:对于Vector&ArrayList、Hashtable&HashMap,要记住线程安全的问题,记住Vector与Hashtable是旧的,是java一诞生就提供了的,它们是线程安全的,ArrayList与HashMap是java2时才提供的,它们是线程不安全的。所以,我们讲课时先讲老的。
即Vector增长原来的一倍,ArrayList增加原来的0.5倍。
6.Array 和 ArrayList 有何区别?
Array 可以包含基本数据类型和引用类型,ArrayList只能包含引用类型。
ArrayList是基于数组实现的,Array大小不可以调整大小,但ArrayList可以通过内部方法自动调整容量。
ArrayList是List接口的实现类,相比Array支持更多的方法和特性。
7.说一下 HashSet 的实现原理?
8.如何决定使用 HashMap 还是 TreeMap?
9.List、Set、Map 之间的区别是什么?
grow()
方法里使用语句newCapacity = oldCapacity + (oldCapacity >> 1)
(即1.5倍扩容)计算容量,然后调用Arrays.copyof()
方法进行对原数组进行复制。newCapacity = (oldCapacity << 1) + 1
)。<K,V>
的开销是固定的,可以通过构造器设置容量和负载因子来调整容器的性能。<K,V>
的顺序是其插入次序,或者是近少使用(LRU)的次序。<K,V>
时,它们会被排序。TreeMap是的带有subMap()
方法的Map,subMap()
可以返回一个子树。10.HashMap怎样解决hash冲突
相关文章