Java集合
集合是什么
Java集合类存放于java.util包中,用来存放对象的容器。
只能存放对象,存放的多个对象的引用,对象本身是放在堆内存中。集合可以存放不同类型。
详细的Java集合框架图:http://blog.csdn.net/u010887744/article/details/50575735
学习集合的目的
1、选取合适的数据结构存储数据
2、学会遍历方法把数据取出来
3、掌握每种集合的特性
集合分类
迭代器Iterator
- java.util.Iterator,遍历集合中所有的元素
- 创建迭代器Iterator,指针索引指向集合-1索引,使用hasNext()方法判断下一个元素是否存在,返回bool类型,移动l.next(),取元素。
- 增强for循环:for each,专门用来遍历数组和集合的。内部原理其实是一个迭代器,在遍历时不能对集合进行增删操做。
泛型
- 集合中的元素是任意存放的,只要把对象集合存储后,这是它们会被提升为对象类型。当我们取出一个对象时,需要进行类型转换。泛型可以在类或方法中预支的使用未知类型。
单列集合
-
顶层接口Collection
-
List
-
有序集合,允许重复
-
ArrayList
- 接口实现类,数组,随机访问,每有同步,线程不安全
-
LinkedList
- 接口实现类,链表,插入删除,没有同步,线程不安全
-
Vector
- 接口实现类,数组,同步,线程安全
- Stack是vector类的实现类
-
-
Set
-
无序集合,不许重复
- 取出元素可以使用迭代器、增强for,不能使用普通for循环,因为是无序的,没有索引
-
HashSet
- 无序,不重复,底层是HashMap支持,根据对象的哈希值来确定元素在集合中的位置,因此具有良好的存取查找性能。存储结构哈希表
- 元素的唯一性需要重写hashCode()和equals()方法来保证。首先判断int类型的hashcode是否相同,若相同还需判断equals判断内容是否相同。
-
LinkedHashSet
- 有序,不重复,底层是链表和哈希表组合的数据结构,链表记录元素存入时的顺序。
-
TreeSet
- 底层二叉树实现,元素唯一且排好序。唯一性需要重写hashcode()和equals()方法。分为自然排序和比较器排序。
-
-
双列集合
-
顶层接口Map
-
键值对,元素键不允许重复,值可以重复
-
HashMap
- 内部实现基于数组+链表,JDK1.8后改为数组+链表+红黑树实现;元素按键值对存储,顺序会根据键值hashcode计算之后存储。
-
TreeMap
- 基于平衡二叉树实现,内部元素顺序存储,由键值对应的类型实现Compareble接口后,实现compare To方法。
-
LinkedHashMap
- 基于链表的Hash Map实现,通过链表实现内部元素的存储顺序和添加顺序一致。
-
HashTable
- Hashtable是同步的,这个类中的一些方法加入了同步关键字,保证HashTable是线程安全的
-