黑马程序员技术交流社区
标题:
Collection集合小结
[打印本页]
作者:
sunriselzz
时间:
2013-8-13 21:24
标题:
Collection集合小结
List接口中常用类
List集合元素有序(存储顺序和取出顺序一致),可重复。
|--ArrayList
底层数据结构是数组,查询速度快,增删慢。线程不安全,效率高。
|--Vector 多数情况下,已被ArrayList替代。
底层数据结构是数组,查询快,增删速度慢,线程安全,效率低。
|--LinkedList
底层数据结构是链表,查询慢,增删快。线程不安全,效率高。
取出LIst集合中元素的方式:
get(int index):通过脚标获取元素。
iterator():通过迭代方法获取迭代器对象。
contains()方法底层依赖的是equals()方法。
Set接口中常用的类
|--Set
|--HashSet
底层数据结构是哈希表结构.线程不安全,存取速度快,无序,唯一,效率高。
保证唯一性:通过equals方法和hashCode方法来保证元素的唯一性。
首先判断hashCode()的值是否相同:
否:直接添加到集合中。 是:继续equals()方法,
返回值true:说明元素重复,不添加。返回值false:直接添加到集合中
|--LinkedHashSet
底层数据结构是链表和哈希表。有序,唯一,线程不安全,效率高。
通过链表结构保证有序,通过哈希表结构保证唯一。
|--TreeSet
有序,唯一,元素是以二叉排序树的形式存放的。线程不安全,效率高。
保证唯一和有序:两种方案。元素本身具备比较性集合具备比较性
实现方案:方式1 元素本身具备比较性,实现Comparable接口
方式2:集合具备比较性,实现Comparator接口可以对集合中的元素进行排序.
通过compareTo或者compare方法来保证元素的唯一性。
它根据返回值是否是0来判断是否重复。
作者:
丁永志
时间:
2013-8-14 07:33
拿资料走人,谢谢楼主。
作者:
╰朕_有恃无恐
时间:
2013-12-8 09:18
很感谢!
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2