您现在的位置是:首页 > 文章详情

Java集合学习总结

日期:2018-03-27点击:353

Java集合学习总结

----------------------------------------------------------------------------- 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。 不知道,就使用ArrayList。 ----------------------------------------------------------------------------- 3:集合的常见方法及遍历方式 Collection(接口): add() remove() contains() iterator() size() 遍历: 增强for 迭代器 |--List get() 遍历: 普通for |--Set --------------------------------------- Map(接口): put() remove() containskey(),containsValue() keySet() values() get() entrySet() size() 遍历: 根据键找值。 根据键值对对象分别找键和值。 ----------------------------------------------------------------------------- 4:ArrayList,LinkedList,HashSet,HashMap(掌握) 存储字符串和自定义对象数据并遍历 ----------------------------------------------------------------------------- 5:集合的嵌套遍历(理解) -----------------------------------------------------------------------------

 

我的GitHub地址: https://github.com/heizemingjun
我的博客园地址: http://www.cnblogs.com/chenmingjun
我的蚂蚁笔记博客地址: http://blog.leanote.com/chenmingjun
Copyright ©2018 黑泽明军
【转载文章务必保留出处和署名,谢谢!】
原文链接:https://yq.aliyun.com/articles/607589
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章