JAVA面试题---容器篇(一)

JAVA容器都有哪些?

1.JAVA容器分为Collection 和  Map两大类,其下又有很多子类,如下所示

Collection

  • List
  • ArrayList
  • LinkedList
  • Vector
          Stack
  • Set
  • HashSet
        LinkedHashSet
  • TreeSet

Map

  • HashMap
  • LinkedHashMap
  • TreeMap
  • ConcurrentHashMap
  • Hashtable

 

2.Collection  和Collections 有什么区别?

  • Collection是一个集合接口,它提供了对集合对象进行基本操作的通用接口方法,所有集合都是它的子类,比如List, Set等
  • Collections是一个包装类,包含了很多静态方法,不能被实例化,就像一个工具类,比如排序方法:Collections.sort(list)
     

3.List 、Set、Map 的区别?

区别主要体现在两个方面:元素是否有序,元素是否重复

 元素有序允许元素重复
List
SetAbstractSet
HashSet
TreeSet是(用二叉树排序)
MapAbstractMapKey值必须唯一,value可以重复
HashMap
TreeMap是(用二叉树排序)

 

 

 

 

 

 

 

 

 

4.HashMap  和  Hashtable 的区别?

  • 存储: HashMap 允许 Key 和 value 为 null, 而Hashtable 不允许。
  • 线程安全:Hashtable是线程安全的,而HashMap是非线程安全的。
  • 推荐使用:在Hashtable 的类注释可以看到,Hashtable 是保留类不建议使用,推荐在单线程环境下使用HasnMap 替代,如果需要多线程使用则用ConcurrentHashMap替代。

5.如何决定使用 HashMap 还是TreeMap

对于在Map中插入、删除、定位一个元素这类操作, HashMap 是最好的的选择,因为相对而言HashMap的插入会更快,但如果要对一个KEY集合进行遍历,那TreeMap是更好的选择。

 

6.HashMap的实现原理?

HashMap是基于Hash算法实现的,我们通过put(key,value)存储,get(key)来获取。当传入KEY值时,HashMap会根据key.hashCode()计算出hash值,根据hash值将value值保存在bucket里。当计算出得hash冲突,HashMap的做法是用链表和红黑树存储相同的hash值和value。当hash冲突比较少时,使用链表否则使用红黑树。

7.HashSet的实现原理

HashSet是基于HashMap实现的,HashSet底层使用HashMap来保存所有元素,因此HashSet的实现比较简单,相关HashSet操作,基本上都是直接调用底层HashMap的相关方法来完成,HashSet不允许重复的值。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值