本文属于转载 http://shihongtao88-163-com.iteye.com/blog/776964
Collection是集合接口
|————Set子接口:无序,不允许重复。
|————List子接口:有序,可以有重复元素。
区别:Collections是集合类
Set和List对比:
Set:检索元素效率低下,删除和插入效率高,插入和删除不会引起元素位置改变。
List:和数组类似,List可以动态增长,查找元素效率高,插入删除元素效率低,因为会引起其他元素位置改变。
Set和List具体子类:
Set
|————HashSet:以哈希表的形式存放元素,插入删除速度很快。
List
|————ArrayList:动态数组。
|————LinkedList:链表、队列、堆栈。
Array和java.util.Vector
Vector是一种老的动态数组,是线程同步的,效率很低,一般不赞成使用。
三、Iterator迭代器(接口)
Iterator是获取集合中元素的过程,实际上帮助获取集合中的元素。
迭代器代替了 Java Collections Framework 中的 Enumeration。迭代器与枚举有两点不同:
迭代器允许调用方利用定义良好的语义在迭代期间从迭代器所指向的集合移除元素。
方法名称得到了改进。
Iterator仅有一个子接口ListIterator,是列表迭代器,允许程序员按任一方向遍历列表、迭代期间修改列表,并获得迭代器在列表中的当前位置。ListIterator 没有当前元素;它的光标位置 始终位于调用 previous() 所返回的元素和调用 next() 所返回的元素之间。在长度为 n 的列表中,有 n+1 个有效的索引值,从 0 到 n(包含)。
四、集合框架之外的Map接口
Map将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射一个值(一一对应)。
Map接口是Dictionary(字典)抽象类的替代品。
Map 接口提供三种collection 视图,允许以键集、值集合或键-值映射关系集的形式查看某个映射的内容。映射的顺序 定义为迭代器在映射的 collection 视图中返回其元素的顺序。某些映射实现可明确保证其顺序,如 TreeMap 类;某些映射实现则不保证顺序,如 HashMap 类。
有两个常见的已实现的子类:
HashMap:基于哈希表的 Map 接口的实现。此实现提供所有可选的映射操作,并允许使用 null 值和 null 键。(除了不同步和允许使用 null 之外,HashMap 类与 Hashtable 大致相同。)此类不保证映射的顺序,特别是它不保证该顺序恒久不变。
TreeMap:它实现SortedMap 接口的基于红黑树的实现。此类保证了映射按照升序顺序排列关键字,根据使用的构造方法不同,可能会按照键的类的自然顺序 进行排序(参见 Comparable),或者按照创建时所提供的比较器进行排序。
Hashtable:此类实现一个哈希表,该哈希表将键映射到相应的值。任何非 null 对象都可以用作键或值。
五、线程安全类
在集合框架中,有些类是线程安全的,这些都是JDK1.1中的出现的。在JDK1.2之后,就出现许许多多非线程安全的类。
下面是这些线程安全的同步的类:
Vector:就比ArrayList多了个同步化机制(线程安全)。
Statck:堆栈类,先进后出。
Hashtable:就比HashMap多了个线程安全。
Enumeration:枚举,相当于迭代器。
除了这些之外,其他的都是非线程安全的类和接口。
线程安全的类其方法是同步的,每次只能一个访问。是重量级对象,效率较低。对于非线程安全的类和接口,在多线程中需要程序员自己处理线程安全问题。
六、其他一些接口和类介绍
Dictionary和Hashtable类:
Dictionary提供键值映射的功能,是个抽象类。一般使用它的子类HashTable类。遍历Hashtable类要用到枚举。
Properties类
Properties 继承于 Hashtable,Properties 类表示了一个持久的属性集。Properties 可保存在流中或从流中加载。属性列表中每个键及其对应值都是一个字符串。一般可以通过读取properties配置文件来填充Properties对象。
分享到:
相关推荐
1. 集合框架层次结构: - **接口**:集合框架的核心是接口,它们定义了特定类型容器的行为。主要接口包括List、Set和Queue。 - `List`:有序的元素集合,允许重复元素,并且元素有索引。典型的实现有ArrayList和...
1. 集合框架的层次结构,解释各种接口和类之间的关系。 2. 泛型的基本用法,包括泛型类、泛型方法、通配符等。 3. 枚举类型的创建和使用,以及它们在集合中的应用。 4. 实例分析,通过具体的代码示例展示如何在实际...
在Java集合框架中,主要分为两大类:Set和Collection。Collection是最基本的接口,它代表了一组不重复元素的序列。Set接口继承自Collection,它不允许有重复的元素,并且不保持元素的插入顺序。而List接口也继承自...
#### 二、集合框架的层次结构 **1. 集合接口 (Collection)** - **Set 子接口**: 表示不包含重复元素的集合,通常用于表示没有固定顺序的元素集合。 - **List 子接口**: 表示有序集合,可以包含重复元素,适合于...
总的来说,Java集合框架是一个强大的工具,它简化了数据存储和操作,通过接口和实现类的层次结构提供了高度的灵活性。了解并熟练掌握这个框架,是任何Java开发者必备的技能之一。通过深入学习和实践,我们可以更好地...
集合框架是一个用来代表和操纵集合的统一架构。所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型。接口允许集合独立操纵其代表的细节。在面向对象的语言,接口通常形成一个层次。 实现(类):是集合...
2. **集合框架层次结构**: - 集合框架的基础是`Collection`接口,它是所有单值集合的根接口。 - `Collection`接口有两个重要的子接口:`Set`和`List`。 - `Set`接口代表无序且不允许重复元素的集合,比如`...
它是所有集合层次结构的根接口,定义了基本的操作,如`size()`、`isEmpty()`、`add()`、`remove()`和`equals()`。`size()`返回集合中元素的数量,`isEmpty()`检查集合是否为空。`add(E e)`方法用于向集合中添加元素...
首先,集合框架的基石是`Collection`接口,它是所有集合类的父接口,位于集合层次结构的顶端。`Collection`接口定义了一系列用于管理对象的方法,如添加元素(`add()`)、删除元素(`remove()`)、检查元素存在性(`...
首先,我们要理解Java集合框架的基本层次结构。它主要包括接口(如List、Set、Map)和实现这些接口的类(如ArrayList、HashSet、HashMap等)。这些接口定义了通用的操作方法,而类则提供了具体的实现。 1. 散列集合...
Collection接口是集合框架中层次结构的根,它提供了一系列操作单个元素的方法,比如添加(add)、删除(remove)、检查是否包含某个元素(contains)、获取元素迭代器(iterator)等。Collection接口下有两个重要的...
首先,我们要了解Java集合框架的基本层次结构。在Java中,集合框架主要由两个顶级接口构成:`Collection`和`Map`。`Collection`接口是所有单值容器的父接口,包括了`List`、`Set`和`Queue`等子接口。`Map`接口则代表...
通过图解的方式,我们可以更清晰地看到这些概念的结构和它们之间的关系,比如类与对象的关系图、异常处理流程图、集合框架层次结构图、多线程的生命周期图等。这些图片能够帮助初学者快速理解并记忆Java的基础知识,...
同时,课程也会深入讲解Java集合框架,这是一个层次化的接口和集合类结构,用于高效实现各种数据结构和算法,从而提升程序性能。 课程设计分为多个模块,包括引例、Java集合框架的应用、递归、列表和有序表、链表、...
#### 二、集合框架层次结构 Java集合框架的设计遵循了良好的面向对象设计原则,其中最顶层的接口是`Collection`,它表示一个元素的集合。`Collection`有两个主要的子接口:`Set`和`List`。 - **`Collection`接口**...
- 集合框架的层次结构图 - 各接口与类的功能介绍 - 实现原理分析 - 操作示例和最佳实践 - 性能比较和选择策略 5. **API文档** Java集合框架的API文档提供了所有接口和类的详细说明,包括构造方法、成员变量、...
Java集合框架是JavaSE标准库中的一个重要组成部分,它为Java程序员提供了一系列接口和类来管理对象集合。集合框架的设计使得程序员在处理数据集合时可以更加高效和方便,无论是在空间的利用还是数据的存取方面。 ...