Java集合框架中的元素

  之前有一篇笔记,讲的是集合和泛型,这几天看Java集合中几个接口的文档,思绪非常混乱,直到看到Oracle的“The Collections Framwork”的页面,条理才清晰些,现在进行整理。

 

  一、为什么需要集合?

  应用程序中经常需要创建很多的对象来完成一定的工作,所以我们需要将这些一定数目的对象组织起来进行统一管理。

  对象数组能够满足我们,如果对象的数目是清晰有限且生命周期可知,那么使用对象数组来进行管理是非常简单和直观的。

  数组一旦创建,它的容量便固定了,在它的生命周期里再也无法被改变。但是程序总是在运行时才根据某些条件去创建新对象,在此之前,我们无法预知所需对象的数量,甚至会不知道确切的类型。那么如何在任意时刻管理任意数量的对象呢?集合便为此诞生了。

  ps:这两种组织和管理对象的方式分别为“array-based”、“collection-based”,在下面提到的集合接口中,有一个方法叫做“toArray()”,被称为两种方式间的桥梁。

 

  二、The Collections Framwork

  Java集合框架到底包含了什么,根据它的API规范做一个总结。

  1、Collection interfaces,即集合接口。

  实现这些接口是我们使用集合的主要方式。它有两个根接口,Collection和Map。

  至于接口的层次结构,这里不再赘述

 

  2、 implementations,即接口实现类

  是对集合接口的各种实现。

  可以看到API规范中列举了多种类型的实现类,其中最基础也最重要的是General-purpose implementations,即通用实现类,里面包含了我们常用的一些数据结构。下表就是常用的接口和它们的常用的实现类:

  

  至于其他的那些 implementations,等有需要了再看,知道实现类种类很多就行。

  

  3、Algorithms ,算法

  提供了一些基本的算法实现。

  这些算法的静态方法都在一个名叫“Collections”的类中(java.util.Collections)。

 

  4、Infrastructure,基础设施

  这个在我看的书本上并没有提,看它的类型就很清楚它的作用了。它里面有4种“基础设施”:

  • Iterators:Iterator、Listiterator
  • Ordering:Comparable、Comparator
  • Runtime exceptions:(两个类)UnsupportedOperationException 、ConcurrentModificationException 
  • Performance:RandomAccess

 

  5、Array Utilities

  里面就包含了Arrays类(java.util.Arrays),因为需要用到很多其中的静态方法!

 

  附一张书本上的“集合框架全景图”:·

 

 

posted @ 2018-03-15 03:27  爆炸的果核  阅读(188)  评论(0编辑  收藏  举报