java集合的主要分为三种类型:
  Set(集)
  List(列表)
  Map(映射)
  要深入理解集合首先要了解下我们熟悉的数组
  数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型),而JAVA集合可以存储和操作数目不固定的一组数据。 所有的JAVA集合都位于 java.util包中! JAVA集合只能存放引用类型的的数据,不能存放基本数据类型。
  简单说下集合和数组的区别:(参考文章:《Thinking In Algorithm》03.数据结构之数组)
  <span style="font-family:Microsoft YaHei;font-size:12px;">世间上本来没有集合,(只有数组参考C语言)但有人想要,所以有了集合
  有人想有可以自动扩展的数组,所以有了List
  有的人想有没有重复的数组,所以有了set
  有人想有自动排序的组数,所以有了TreeSet,TreeList,Tree**
  而几乎有有的集合都是基于数组来实现的.
  因为集合是对数组做的封装,所以,数组永远比任何一个集合要快
  但任何一个集合,比数组提供的功能要多
  一:数组声明了它容纳的元素的类型,而集合不声明。这是由于集合以object形式来存储它们的元素。
  二:一个数组实例具有固定的大小,不能伸缩。集合则可根据需要动态改变大小。
  三:数组是一种可读/可写数据结构---没有办法创建一个只读数组。然而可以使用集合提供的ReadOnly方法,以只读方式来使用集合。该方法将返回一个集合的只读版本。</span>
  Java所有“存储及随机访问一连串对象”的做法,array是有效率的一种。
  1、效率高,但容量固定且无法动态改变。
  array还有一个缺点是,无法判断其中实际存有多少元素,length只是告诉我们array的容量。
  2、Java中有一个Arrays类,专门用来操作array。
  arrays中拥有一组static函数
  equals():比较两个array是否相等。array拥有相同元素个数,且所有对应元素两两相等。
  fill():将值填入array中。
  sort():用来对array进行排序。
  binarySearch():在排好序的array中寻找元素。
  System.arraycopy():array的复制。
  若撰写程序时不知道究竟需要多少对象,需要在空间不足时自动扩增容量,则需要使用容器类库,array不适用。所以要用到集合。
  那我们开始讨论java中的集合。
  集合分类:
  Collection:List、Set
  Map:HashMap、HashTable
  1.1 Collection接口
  Collection是基本的集合接口,声明了适用于JAVA集合(只包括Set和List)的通用方法。 Set 和List 都继承了Conllection,Map。
  1.1.1  Collection接口的方法:
  <span style="font-weight: normal;">boolean add(Object o)      :向集合中加入一个对象的引用
  void clear():删除集合中所有的对象,即不再持有这些对象的引用
  boolean isEmpty()    :判断集合是否为空
  boolean contains(Object o) : 判断集合中是否持有特定对象的引用
  Iterartor iterator()  :返回一个Iterator对象,可以用来遍历集合中的元素
  boolean remove(Object o) :从集合中删除一个对象的引用
  int size()       :返回集合中元素的数目
  Object[] toArray()    : 返回一个数组,该数组中包括集合中的所有元素 </span>
  关于:Iterator() 和toArray() 方法都用于集合的所有的元素,前者返回一个Iterator对象,后者返回一个包含集合中所有元素的数组。
  1.1.2  Iterator接口声明了如下方法:
  hasNext():判断集合中元素是否遍历完毕,如果没有,返回true
  next() :返回下一个元素
  remove():从集合中删除上一个有next()方法返回的元素。