java 集合类Array、List、Map区别和联系

java集合类主要分为如下三类: java

第一类:Array、Arrays 数据库

第二类:Collection :List、Set
第三类:Map :HashMap、HashTable
数组

 

1、Array , Arrays 函数

Java全部“存储及随机访问一连串对象”的作法,array是最有效率的一种。 spa

一、
效率高,但容量固定且没法动态改变。
array还有一个缺点是,没法判断其中实际存有多少元素,length只是告诉咱们array的容量。
线程

二、Java中有一个Arrays类,专门用来操做array 
    arrays中拥有一组static函数,
equals():比较两个array是否相等。array拥有相同元素个数,且全部对应元素两两相等。
fill():将值填入array中。
sort():用来对array进行排序。
binarySearch():在排好序的array中寻找元素。
System.arraycopy():array的复制。
指针


2、Collection , Map 对象

若撰写程序时不知道究竟须要多少对象,须要在空间不足时自动扩增容量,则须要使用容器类库,array不适用。 排序

一、Collection 和 Map 的区别 继承

容器内每一个为之所存储的元素个数不一样。
Collection类型者,每一个位置只有一个元素。
Map类型者,持有 key-value pair,像个小型数据库。

二、各自旗下的子类关系

Collection
    --List : 将以特定次序存储元素。因此取出来的顺序可能和放入顺序不一样。
          --ArrayList / LinkedList / Vector
    --Set : 不能含有重复的元素
          --HashSet / TreeSet 
Map 
    --HashMap
    -- HashTable
    -- TreeMap

三、其余特征

*  List,Set,Map将持有对象一概视为Object型别。
*  Collection、List、Set、Map都是接口,不能实例化。
   继承自它们的 ArrayList, Vector, HashTable, HashMap是具象class,这些才可被实例化。
*  vector容器确切知道它所持有的对象隶属什么型别。vector不进行边界检查。


3、Collections

Collections是针对集合类的一个帮助类。 提供了一系列静态 方法实现对各类集合的搜索、排序、线程彻底化等操做。
至关于对Array进行相似操做的类——Arrays。
如,Collections.max(Collection coll); 取coll中最大的元素。
    Collections.sort(List list); 对list中元素排序

4、如何选择?

一、容器类和Array的区别、择取 
   *  容器类仅能持有对象引用(指向对象的指针),而不是将对象信息copy一份至数列某位置。
   *  一旦将对象置入容器内,便损失了该对象的型别信息。

二、 
  *  在各类Lists中,最好的作法是以ArrayList做为缺省选择。当插入、删除频繁时,使用LinkedList();
     Vector老是比ArrayList慢,因此要尽可能避免使用。
  *  在各类Sets中,HashSet一般优于HashTree(插入、查找)。只有当须要产生一个通过排序的序列,才用TreeSet。
     HashTree存在的惟一理由:可以维护其内元素的排序状态。
  *  在各类Maps中
     HashMap用于快速查找。
  *  当元素个数固定,用Array,由于Array效率是最高的。

结论:最经常使用的是ArrayList,HashSet,HashMap,Array。


注意:

一、Collection没有get()方法 来取得某个元素。只能经过iterator()遍历元素。
二、Set 和Collection拥有如出一辙的接口。
三、List ,能够经过get()方法来一次取出一个元素 。使用数字来选择一堆对象中的一个,get(0)...。(add/get)
四、通常使用ArrayList。用LinkedList构造堆栈stack、队列queue 。

五、Map用 put(k,v) / get(k) ,还可使用containsKey()/containsValue()来检查其中是否含有某个key/value。
   HashMap会利用对象的hashCode来快速找到key。
    *  hashing
       哈希码就是将对象的信息通过一些转变造成一个独一无二的int值,这个值存储在一个array中。
       咱们都知道全部存储结构中,array查找速度是最快的。因此,能够加速查找。
      
       发生碰撞时,让array指向多个values。即,数组每一个位置上又生成一个梿表。

六、Map中元素,能够将key序列、value序列单独抽取出来。
使用keySet() 抽取key序列,将map中的全部keys生成一个Set。
使用values( ) 抽取value序列,将map中的全部values生成一个Collection。

为何一个生成Set,一个生成Collection?那是由于,key老是独一无二的,value容许重复。

相关文章
相关标签/搜索