Java 数据 -- 集合
来源:互联网 发布:淘宝退货折旧费怎么算 编辑:程序博客网 时间:2024/06/05 23:54
1:集合 Collection(单列集合) List(有序,可重复) ArrayList 底层数据结构是数组,查询快,增删慢 线程不安全,效率高 Vector 底层数据结构是数组,查询快,增删慢 线程安全,效率低 LinkedList 底层数据结构是链表,查询慢,增删快 线程不安全,效率高 Set(无序,唯一) HashSet 底层数据结构是哈希表。 哈希表依赖两个方法:hashCode()和equals() 执行顺序: 首先判断hashCode()值是否相同 是:继续执行equals(),看其返回值 是true:说明元素重复,不添加 是false:就直接添加到集合 否:就直接添加到集合 最终: 自动生成hashCode()和equals()即可 LinkedHashSet 底层数据结构由链表和哈希表组成。 由链表保证元素有序。 由哈希表保证元素唯一。 TreeSet 底层数据结构是红黑树。(是一种自平衡的二叉树) 如何保证元素唯一性呢? 根据比较的返回值是否是0来决定 如何保证元素的排序呢? 两种方式 自然排序(元素具备比较性) 让元素所属的类实现Comparable接口 比较器排序(集合具备比较性) 让集合接收一个Comparator的实现类对象 Map(双列集合) A:Map集合的数据结构仅仅针对键有效,与值无关。 B:存储的是键值对形式的元素,键唯一,值可重复。 HashMap 底层数据结构是哈希表。线程不安全,效率高 哈希表依赖两个方法:hashCode()和equals() 执行顺序: 首先判断hashCode()值是否相同 是:继续执行equals(),看其返回值 是true:说明元素重复,不添加 是false:就直接添加到集合 否:就直接添加到集合 最终: 自动生成hashCode()和equals()即可 LinkedHashMap 底层数据结构由链表和哈希表组成。 由链表保证元素有序。 由哈希表保证元素唯一。 Hashtable 底层数据结构是哈希表。线程安全,效率低 哈希表依赖两个方法:hashCode()和equals() 执行顺序: 首先判断hashCode()值是否相同 是:继续执行equals(),看其返回值 是true:说明元素重复,不添加 是false:就直接添加到集合 否:就直接添加到集合 最终: 自动生成hashCode()和equals()即可 TreeMap 底层数据结构是红黑树。(是一种自平衡的二叉树) 如何保证元素唯一性呢? 根据比较的返回值是否是0来决定 如何保证元素的排序呢? 两种方式 自然排序(元素具备比较性) 让元素所属的类实现Comparable接口 比较器排序(集合具备比较性) 让集合接收一个Comparator的实现类对象2.关于集合选取原则 是否是键值对象形式: 是:Map 键是否需要排序: 是:TreeMap 否:HashMap 不知道,就使用HashMap。 否:Collection 元素是否唯一: 是:Set 元素是否需要排序: 是:TreeSet 否:HashSet 不知道,就使用HashSet 否:List 要安全吗: 是:Vector 否:ArrayList或者LinkedList 增删多:LinkedList 查询多:ArrayList 不知道,就使用ArrayList 不知道,就使用ArrayList3:集合的常见方法及遍历方式 Collection: add() remove() contains() iterator() size() 遍历: 增强for 迭代器 |--List get() 遍历: 普通for |--Set Map: put() remove() containskey(),containsValue() keySet() get() value() entrySet() size() 遍历: 根据键找值 根据键值对对象分别找键和值
阅读全文
0 0
- java数据集合
- java 数据集合
- Java 数据 -- 集合
- java数据集合Map接口
- java集合初探之数据
- Java数据集合-学习总结
- java常见数据集合分析
- java集合中大量数据的匹配
- java基础 数据集合 hashmap hashtable
- Java集合数组列表中的数据排序
- Java 对象集合数据导出到Excel
- java 数据集合(set、map、list)
- java大数据两集合的交集
- java中List集合数据灵活转换
- java list集合数据升序降序排序
- Java数据和集合的对比
- Java:使用Iterator迭代器遍历集合数据
- Java集合数据存储的总结
- NOIP复赛复习(十)怎样才能拿到高分?
- 跟大师学习系统编程---操作系统加载(6)
- 6-16 Topological Sort(25 point(s))
- golang进阶(六)——restful开发优雅处理error
- oracle 11.2.0.3 expdp 时报错,ORA-39181: Only partial table data may be exported due to fine grain
- Java 数据 -- 集合
- 跟大师学习系统编程---操作系统加载(7)
- 实现网页布局
- NOIP复赛复习(八)STL算法与树结构模板
- Android Studio的安装与下载
- 6-1 单链表逆转(20 point(s))
- IntelliJ IDEA中怎么查看文件中所有方法(类似eclipse里面的outline)
- 任玉刚:让你的职业迷茫从哪来回哪去
- 6-2 顺序表操作集(20 point(s))