Java面试整理 关于集合
2017-03-06 16:49
260 查看
Set,List,Map的区别
java集合的主要分为三种类型:Set(集)
List(列表)
Map(映射)
Set是最简单的一种集合。集合中的对象不按特定的方式排序,并且没有重复对象。
List的特征是其元素以线性方式存储,集合中可以存放重复对象。
Map 是一种把键对象和值对象映射的集合,它的每一个元素都包含一对键对象和值对象。 Map没有继承于Collection接口 从Map集合中检索元素时,只要给出键对象,就会返回对应的值对象。
Collection
--List:将以特定次序存储元素。所以取出来的顺序可能和放入顺序不同。
--ArrayList / LinkedList / Vector
--Set : 不能含有重复的元素
--HashSet / TreeSet
Map
--HashMap
--HashTable
--TreeMap
Array可以包含基本类型和对象类型,ArrayList只能包含对象类型。
Array大小是固定的,ArrayList的大小是动态变化的。
ArrayList提供了更多的方法和特性,比如:addAll(),removeAll(),iterator()等等。
对于基本类型数据,集合使用自动装箱来减少编码工作量。但是,当处理固定大小的基本数据类型的时候,这种方式相对比较慢。
ArrayList和LinkedList有什么区别?
ArrayList和LinkedList都实现了List接口,他们有以下的不同点:ArrayList是基于索引的数据接口,它的底层是数组。它可以以O(1)时间复杂度对元素进行随机访问。与此对应,LinkedList是以元素列表的形式存储它的数据,每一个元素都和它的前一个和后一个元素链接在一起,在这种情况下,查找某个元素的时间复杂度是O(n)。
相对于ArrayList,LinkedList的插入,添加,删除操作速度更快,因为当元素被添加到集合任意位置的时候,不需要像数组那样重新计算大小或者是更新索引。
LinkedList比ArrayList更占内存,因为LinkedList为每一个节点存储了两个引用,一个指向前一个元素,一个指向下一个元素。
arraylist和vector的区别
1、Vector是多线程安全的,而ArrayList不是,这个可以从源码中看出,Vector类中的方法很多有synchronized进行修饰,这样就导致了Vector在效率上无法与ArrayList相比;2、两个都是采用的线性连续空间存储元素,但是当空间不足的时候,两个类的增加方式是不同的,ArrayList在内存不够时默认是扩展50% + 1个,Vector是默认扩展1倍。
3、Vector提供indexOf(obj, start)接口,ArrayList没有。
为什么Map不继承Collection接口?
Map被设计为键值对的集合,所以不需要继承Collection接口。如果Map继承Collection接口,那么元素去哪儿?Map包含key-value对,它提供抽取key或value列表集合的方法,但是它不适合“一组对象”规范。
HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,
主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable。
HashMap允许将null作为一个entry的key或者value,而Hashtable不允许。HashMap把Hashtable的contains方法去掉了,改成containsvalue和containsKey。因为contains方法容易让人引起误解。
Hashtable继承自D
d410
ictionary类,而HashMap是Java1.2引进的Map interface的一个实现。
最大的不同是,Hashtable的方法是Synchronize的,而HashMap不是,在多个线程访问Hashtable时,不需要自己为它的方法实现同步,而HashMap 就必须为之提供外同步(Collections.synchronizedMap)。
Hashtable和HashMap采用的hash/rehash算法都大概一样,所以性能不会有很大的差异。
HashMap Hashtable
父类 AbstractMap Dictiionary
是否同步 否 是
k,v可否null 是 否
HashMap和TreeMap的区别
HashMap:底层是哈希表数据结构。线程不同步。TreeMap:底层是二叉树数据结构,线程不同步,可用于给Map集合中的键进行排序
Java集合中线程安全的类
在集合框架中,有些类是线程安全的,这些都是jdk1.1中的出现的。在jdk1.2之后,就出现许许多多非线程安全的类。 下面是这些线程安全的同步的类:
vector:就比arraylist多了个同步化机制(线程安全),因为效率较低,现在已经不太建议使用。在web应用中,特别是前台页面,往往效率(页面响应速度)是优先考虑的。
statck:堆栈类,先进后出
hashtable:就比hashmap多了个线程安全
enumeration:枚举,相当于迭代器
除了这些之外,其他的都是非线程安全的类和接口。
TreeMap 和 TreeSet 是 Java Collection Framework 的两个重要成员,其中 TreeMap 是 Map 接口的常用实现类,而 TreeSet 是 Set 接口的常用实现类。虽然TreeMap 和TreeSet 实现的接口规范不同,但
TreeSet 底层是通过 TreeMap 来实现的(如同HashSet底层是是通过HashMap来实现的一样),因此二者的实现方式完全一样。而 TreeMap 的实现就是红黑树算法。
相关文章推荐
- Java面试整理 关于线程
- Java面试整理 关于抽象类和接口
- Java面试整理 关于hibernate
- Java面试整理 关于Spring
- java 中关于集合类的整理01
- 关于Java中集合:List,Set ,Map,整理
- 神州数码的面试集合(前人整理,在此感谢)
- 关于this和super使用的JAVA面试试题
- java面试笔试题整理
- java面试笔试题整理
- 关于java的集合类,以及HashMap中Set的用法!
- java面试笔试题整理
- 整理的关于Java参数传递的研究
- java面试整理(二)[http://blog.csdn.net/mlovex/]
- 面试大连花旗的必看--java面试笔试题整理(2)
- 关于java的集合类,以及HashMap中Set的用法!
- 关于依懒属性文章集合整理
- java面试笔试题整理
- java面试整理(一)[From http://blog.csdn.net/mlovex/]
- JAVA基础笔试、面试常见问题集合