Java集合框架概要

Java Collection Framework:Java集合框架

在Java语言中,Java语言的设计者对常用的数据结构和算法做了一些规范(接口)和实现(具体实现接口的类)。所有抽象出来的数据结构和操作(算法)统称为Java集合框架。

Javav程序员在具体应用时,不必考虑数据结构和算法实现细节,只需要用这些类创造出来一些对象,然后直接应用就可以了。大大提高了编程效率。

Java集合框架的基本接口/类层次结构:

注:[I]表示接口、[C]表示类

java.util.Collection [I]

+--java.util.List [I]

+--java.util.ArrayList [C]

+--java.util.LinkedList [C]

+--java.util.Vector [C]

+--java.util.Stack

+--java.util.Set [I]

+--java.util.HashSet [C]

+--java.util.SortedSet [I]

+--java.util.TreeSet [C]

java.util.Map [I]

+--java.util.SortedMap [I]

+--java.util.TreeMap [C]

+--java.util.Hashtable [C]

+--java.util.HashMap [C]

+--java.util.LinkedHashMap [C]

+--java.util.WeakHashMap [C]

对集合操作的工具类:

Java提供了java.Util.Collections和java.util.Arrays两个工具类简化了对集合的操作。

(注意:java.util.Collection是一个接口,是Java集合层次的根接口。java.util.Collections是一个对集合提供一些操作的工具类)

java.util.Collections提供了一些static方法用来操作或创建Collection,Map集合。

java.util.Arrays主要提供static方法来对数组进行操作。

线程安全的类:

Vector:比ArrayList多了线程同步机制。

Stack:堆栈类。

Hashtable:比HashMap多了线程安全。

Collection接口是所有集合接口的积累,提供了集合接口的通用操作。

定义如下:

public
interface
Collection<E>
extends
Iterable<E>
{

 

// Basic operations

 

int
size();

 

boolean
isEmpty();

 

boolean
contains(Object element);

 

boolean
add(E element);
//optional

 

boolean
remove(Object element);
//optional

 

Iterator<E>
iterator();

 

 

// Bulk operations

 

boolean
containsAll(Collection<?> c);

 

boolean
addAll(Collection<?
extends E> c);
//optional

 

boolean
removeAll(Collection<?> c);
//optional

 

boolean
retainAll(Collection<?> c);
//optional

 

void
clear();
//optional

 

 

// Array operations

 

Object[]
toArray();

 

<T>
T[] toArray(T[]
a);

 

}

List是一个顺序的Collection(通常被称作序列)。通常也代表一个线性表的数据结构。List可以包含重复元素。List接口基本功能如下:

按位置访问—通过元素在list中的位置索引访问元素。

查询—获取某元素在list中的位置。

迭代—扩展了Iterator的接口能实现更多的功能,可以在链表中间添加元素。

List子集合—获取List某个位置范围内的子集合。

public
interface
List<E>
extends
Collection<E>
{

 

// Positional access

 

E get(int
index);

 

E set(int
index, E element);
//optional

 

boolean
add(E element);
//optional

 

void
add(int index, E element);
//optional

 

E remove(int
index);
//optional

 

boolean
addAll(int index,

 

Collection<?
extends E> c);
//optional

 

 

// Search

 

int
indexOf(Object o);

 

int
lastIndexOf(Object o);

 

 

// Iteration

 

ListIterator<E>
listIterator();

 

ListIterator<E>
listIterator(int index);

 

 

// Range-view

 

List<E>
subList(int from,
int to);

 

}

Java提供了两个泛型的List的实现:LinkedList(链表)和ArrayList(数组列表)

ArrayList底层采用数组来保存每个集合元素。

LinkedList则是链式存储的线性表,本质是双向链表。我们可以把LinkedList当做栈来使用。

Set是一个不包含重复元素的无序集合(Collection)。Set接口中的函数都是从Collection继承而来。但限制了add的使用,使其不能添加重复元素。

Set接口声明如下:

public
interface
Set<E>
extends
Collection<E>
{

 

// Basic operations

 

int
size();

 

boolean
isEmpty();

 

boolean
contains(Object element);

 

boolean
add(E element);
//optional

 

boolean
remove(Object element);
//optional

 

Iterator<E>
iterator();

 

 

// Bulk operations

 

boolean
containsAll(Collection<?> c);

 

boolean
addAll(Collection<?
extends E> c);
//optional

 

boolean
removeAll(Collection<?> c);
//optional

 

boolean
retainAll(Collection<?> c);
//optional

 

void
clear();
//optional

 

 

// Array Operations

 

Object[]
toArray();

 

<T>
T[] toArray(T[]
a);

 

}

Java中包含了三个通用的Set实现:HashSet,TreeSet和LinkedHashSet。

HashSet通过hash表存储集合元素。TreeSet的底层通过TreeMap的key来保存set集合的元素,而TreeMap采用红黑树(二叉排序树)来保存Map每个Entry。LinkedHashSet通过通过链表存储集合元素。

Map是Java提供的一个接口。Map是一种包含键值对的元素的集合。Map不能包含重复的键,并可以通过键实现对值得快速访问。


public interface Map<K,V> {

 

 

 

    // Basic operations

 

    V put(K key, V value);

 

    V get(Object key);

 

    V remove(Object key);

 

    boolean containsKey(Object key);

 

    boolean containsValue(Object value);

 

    int size();

 

    boolean isEmpty();

 

 

 

    // Bulk operations

 

    void putAll(Map<? extends K, ? extends V> m);

 

    void clear();

 

 

 

    // Collection Views

 

    public Set<K> keySet();

 

    public Collection<V> values();

 

    public Set<Map.Entry<K,V>> entrySet();

 

 

 

    // Interface for entrySet elements

 

    public interface Entry {

 

       K getKey();

 

       V getValue();

 

       V setValue(V value);

 

    }

 

}

Java平台中提供了三种通用的Map实现:HashMap,TreeMap和LinkedHashMap。此外,哈希表也实现了Map接口。

Map不提供迭代器,而是提供3种方法,将Map对象的视图作为Collection对象返回。由于这些视图本身就是Collection,因此它们可以被迭代。

Set<KeyType> keySet()

Collection<ValueType> values()

Set<Map.Entry<KeyType,ValueType>> entrySet()

public
interface
Map<K,V>
{

 

 

// Basic operations

 

V put(K
key, V value);

 

V get(Object
key);

 

V remove(Object
key);

 

boolean
containsKey(Object key);

 

boolean
containsValue(Object value);

 

int
size();

 

boolean
isEmpty();

 

 

// Bulk operations

 

void
putAll(Map<?
extends K,
?
extends V> m);

 

void
clear();

 

 

// Collection Views

 

public
Set<K> keySet();

 

public
Collection<V> values();

 

public
Set<Map.Entry<K,V>>
entrySet();

 

 

// Interface for entrySet
elements

 

public
interface
Entry
{

 

K getKey();

 

V getValue();

 

V setValue(V
value);

 

}

 

}

因为在Map中不能有重复的键,所以keySet和entrySet是Set对象。

时间: 2024-11-09 00:10:41

Java集合框架概要的相关文章

Java—集合框架List

集合的概念 现实生活中:很多的事物凑在一起 数学中的集合:具有共同属性的事物的总和 Java中的集合类:是一种工具类,就像是容器,存储任意数量的具有共同属性的对象 集合的作用 在类的内部,对数据进行组织(针对作用与意义一样的属性,将他们放到一个集合中) 简单而快速的搜索大数量的条目 有的集合接口,提供了一系列排列有序的元素,并且可以在序列中快速的插入或删除有关元素 有的集合接口,提供了映射关系,可以通过关键字(key)去快速查找到对应的唯一对象,而这个关键字可以是任意类型 与数组相比 数组的长度

《深入理解Java集合框架》系列文章

Introduction 关于C++标准模板库(Standard Template Library, STL)的书籍和资料有很多,关于Java集合框架(Java Collections Framework, JCF)的资料却很少,甚至很难找到一本专门介绍它的书籍,这给Java学习者们带来不小的麻烦.我深深的不解其中的原因.虽然JCF设计参考了STL,但其定位不是Java版的STL,而是要实现一个精简紧凑的容器框架,对STL的介绍自然不能替代对JCF的介绍. 本系列文章主要从数据结构和算法层面分析

JAVA集合框架

收藏 查看我的收藏 146有用+1 56 编辑 Java,是由Sun Microsystems公司于1995年5月推出的Java程序设计语言和Java平台的总称.用Java实现的HotJava浏览器(支持Java applet)显示了Java的魅力:跨平台.动态的Web.Internet计算.从此,Java被广泛接受并推动了Web的迅速发展,常用的浏览器现在均支持Java applet.集合框架是为表示和操作集合而规定的一种统一的标准的体系结构.任何集合框架都包含三大块内容:对外的接口.接口的实

我所理解Java集合框架的部分的使用(Collection和Map)

所谓集合,就是和数组类似--一组数据.java中提供了一些处理集合数据的类和接口,以供我们使用. 由于数组的长度固定,处理不定数量的数据比较麻烦,于是就有了集合. 以下是java集合框架(短虚线表示接口,长虚线表示抽象类,实线表示类,箭头表示实现接口或者继承)(在网络上找的图,不知道原作者,侵权请联系我删除)(总之,关系很复杂,所以不用记得这个图,只是用来吓吓人而已的). 下面贴上个人理解之精简版之Collection(集)和Map(地图?暂且这么理解吧),话说思维导图蛮好用,以下是两幅思维导图

【Java集合源码剖析】Java集合框架

Java集合工具包位于package java.util下.包含了一些常用的数据结构,如数组.链表(单/双向).树.栈.队列.哈希表等. Java集合框架大致可分为五部分:List列表.Set集合.Map映射.迭代器(Iterator.Enumeration).工具类(Arrays.Collections). Java集合类的整体框架如下: 如图,Java集合类大致分为两大类:Collection和Map. Collection主要包括两部分:List和Set. List接口通常表示一个列表(数

Java集合框架总结(3)——TreeSet类的排序问题

Java集合框架总结(3)--TreeSet类的排序问题 TreeSet支持两种排序方法:自然排序和定制排序.TreeSet默认采用自然排序. 1.自然排序 TreeSet会调用集合元素的compareTo(Object obj)方法来比较元素之间大小关系,然后将集合元素按升序排列,这种方式就是自然排序.(比较的前提:两个对象的类型相同). java提供了一个Comparable接口,该接口里定义了一个compareTo(Object obj)方法,该方法返回一个整数值,实现该接口的类必须实现该

2016.3.9-3.10(java集合框架)

3.9 集合框架有什么作用? 集合框架其主要功能是用来将存储的数据以某种结构组织,并以特定的方式来访问这些数据. Java集合框架中有哪些存储方式? Java集合框架中的对象容器,按照对象在其中的存储方式,分为Set.List.和Map三种类型. Set类型对象没有顺序,且不能重复: List类型对象容器中的对象按照索引顺序排序,而且可以有重复的对象: Map类型对象容器中的元素包含一对“键对象-值对象”映射,其中键对象不能重复,值对象可以重复. 以上三种存储方式对应Java集合框架中Set.L

java集合框架22

思想:在面向对象的思想里,一种数据结构被认为是一种容器.在本质上来讲是一个类,提供方法支持查找,插入和删除等等操作. Java集合框架支持以下俩种类型的容器: 存储一个元素集合,简称为集合Collection 存储键值对,称为图Map 集合collection 三种主要类型 : 规则集(set) , 线型表(List) , 队列(Queue) set: 存储一组不重复的数据 List: 存储由元素构成的有序集合 Queue: 存储先进先出方式处理的对象 细说Collection接口: 它是处理对

Java集合框架的知识总结

说明:面试准备,写的挺不错的. 转载地址: http://www.cnblogs.com/zhxxcq/archive/2012/03/11/2389611.html 1.综述 所有集合类都位于java.util包下.集合中只能保存对象(保存对象的引用变量).(数组既可以保存基本类型的数据也可以保存对象). 当我们把一个对象放入集合中后,系统会把所有集合元素都当成Object类的实例进行处理.从JDK1.5以后,这种状态得到了改进:可以使用泛型来限制集合里元素的类型,并让集合记住所有集合元素的类