l概念分类
Java 2将容器分为两个不同的概念: Collection 与Map
Collection: 提供对一组各自独立的元素的集合,List 与 Set接口都继承自Collection接口。
Map:提供了一组key-value(键值对)。
两种类型的主要区别在于:
Collection类型每个位置只持有一个元素(Object),比如List以加入到容器中的先后顺序来持有一个独立的的对象。Set中的对象不得重复,并且它会使用自己内部的一种排序机制。
Map类型所持有的是key-value(键值对),Map不接受重复的key。
l容器分类
Java的所有容器类都实现了来自于List, Set, Map三种接口中的一个。我们可以通过Think in Java里面的类图来观察他们之间的关系:
lList
List定义了一个线性表接口,Java2中的List实现方式分为两种:
ArrayList 是以array(数组)实现的线性表数据结构,其get(int index)方法的时间复杂度为O(1)。而其插入与删除操作的元素在中央时,其效率较低。因为每次都要对插入或删除位置(index)后面的array的进行数组拷贝。
LinkedList 是一个双向链表数据结构。其插入与删除操作效率要明显高于ArrayList。
而且其随机查找的时间复杂度为O(n) (其实每次随机查找的次数要依赖于size/2到要查找的目标index之间的个数)其查找的效率要低于ArrayList的O(1)。
lSet
Set是集合类,该集合不能有“重复”对象存在,Java2中Set实现方式分成两种:
HashSet 将持有对象映射到在哈希表中。 (JDK1.6的内部实现是 HashSet只是个适配器,其将适配对象HashMap适配成了Set接口)
TreeSet 将持有对象放入RBTree(红黑树)中。(TreeSet也将适配对象TreeMap适配成了Set接口)
l Map
Map是一组key-value(键值对)集合,其中的key(键)不能重复。
HashMap 用key对象生成hashcode然后映射到Entry<K,V>[]数组中(JDK1.6中其hashtable默认大小为16,在持有对象数量查过默认大小之后就会重新生成一个更大HashTable,然后将原有持有的对象逐个散列到新哈希表中)。其get(Object key) 最佳时间复杂度为O(1),最坏则为O(n)。但就查找的平均效率来说是要高于TreeMap。
TreeMap 用key对象为关键值存放在RBTree(红黑树)中。其get(Object key)方法的平均时间复杂度为O(logn)。
l Iterator
Iterator迭代器实现对: 哈希表HashMap,红黑树TreeMap,链表LinkedList,动态数组ArrayList等数据结构的迭代。
所有的Collection都可以获得一个Iterator对象用来遍历自己的所持有的对象。
分享到:
相关推荐
java容器
JAVA 容器类应用JAVA 容器类应用JAVA 容器类应用JAVA 容器类应用JAVA 容器类应用JAVA 容器类应用JAVA 容器类应用
Java 容器详解 Java 容器是 Java 语言中的一种集合类库,主要包括 Collection 和 Map 两种类型。Collection 存储着对象的集合,而 Map 存储着键值对(两个对象)的映射表。 Collection Collection 是一种集合接口...
Java 容器的两种基本类型:Collection 和 Map Collection 和 Map 是 Java 中的两种基本容器类型,它们都可以用来存储和管理对象,但它们有着不同的特点和用途。 Collection 是一种聚集对象的容器,每个位置只能...
Java容器讲解PPT,Collection Map(HashMap TreeMap LinkedHashMap) List (ArrayList LinkedList Vector) Set (HashSet TreeSet LinkedHashSet)
题目摘要:考虑下列的信息系统。出版社需要记录下列书籍和作者的信息: P1: 每一本书有一个title,一个description和一个ISBN number 还有 出版的日期(包括年/月) P2: 每一本书有1个或多个作者。...
主要是介绍java容器的相关信息,是初学者很好的学习材料
对于java容器的一些归纳整理,顺着思维导图能方便自己的理解,提高运用能力
JAVA 容器用法详解,关于JAVA容器的详细讲解
后缀为.mmap的思维导图,总结了JAVA容器的常见类
NULL 博文链接:https://newtime.iteye.com/blog/431572
JAVA容器一些基础题
Java容器学习笔记: 容器概览, 容器中的设计模式, 容器源码分析 - List, 容器源码分析 - Map, 容器源码分析 - 并发容 Java是一种面向对象的编程语言,由Sun Microsystems于1995年推出。它是一种跨平台的语言,...
JAVA容器基础知识,分析及使用方法,知识总结,数组,List,set,Map
java容器简介 Array对象 List Set 迭代器Iterator
Java容器提供了一种统一的方式来组织和管理多个对象,使得开发者能够更加方便地对这些对象进行操作和处理。 Java容器主要分为两大类:Collection 和 Map。 Collection: Collection表示一组对象,它的主要子接口...
Collection 表示一组对象,它是集中,收集的意思,就是把一些数据收集起来 Collection接口的两个子接口: Set中的数据没有顺序,不可重复。 List中的数据有顺序,可重复。
NULL 博文链接:https://howarezhao.iteye.com/blog/1323147
JAVA容器的概述,List,Map,Set