Java基础知识强化之集合框架笔记72:集合特点和数据结构总结
1. 集合
(1)Collection(单列集合)
List(有序,可重复):
ArrayList:底层数据结构是数组,查询块,增删慢。线程不安全,效率高
Vector:底层数据结构是数组,查询快,增删慢。线程安全,效率低
LinkedList:底层数据结构是链表,查询慢,增删块。线程不安全,效率高。
Set(无序,唯一):
HashSet:底层数据结构是哈希表,哈希表依赖于两个方法:hashCode()和equals()。
执行顺序:
首先判断hashCode()值是否相同 ?
是:继续执行equals(),看其返回值
是true:说明元素重复,不添加
是false:就直接添加到集合
否:就直接添加到集合
最终:
自动生成hashCode()和equals()即可.
LinkedHashSet:底层数据结构由链表和哈希表组成。
由链表保证元素的有序,由哈希表保证元素的唯一。
TreeSet:
底层数据结构是红黑树(是一种自平衡的二叉树)
如何保证元素的唯一性?
根据比较的返回值是否是0来决定
如何保证元素的排序呢?
两种方式:
自然排序(元素具备比较性)
让元素所属的类实现Comparable接口
比较器排序(集合具备比较性)
让集合接收一个Comparator的实现类对象
(2)Map(双列集合)
• Map集合的数据结构仅仅针对键有效,与值无关。
• 存储的是键值对形式的元素,键唯一,值可重复。
HashMap:
底层数据结构是哈希表。线程不安全,效率高
哈希表依赖两个方法:hashCode()和equals()
执行顺序:
首先判断hashCode()值是否相同
是:继续执行equals(),看其返回值
是true:说明元素重复,不添加
是false:就直接添加到集合
否:就直接添加到集合
最终:
自动生成hashCode()和equals()即可
LinkedHashMap:
底层数据结构由链表和哈希表组成。
由链表保证元素有序。
由哈希表保证元素唯一。
Hashtable:
底层数据结构是哈希表。线程不安全,效率低
哈希表依赖两个方法:hashCode()和equals()
执行顺序:
首先判断hashCode()值是否相同
是:继续执行equals(),看其返回值
是true:说明元素重复,不添加
是false:就直接添加到集合
否:就直接添加到集合
最终:
自动生成hashCode()和equals()即可
TreeMap:
底层数据结构是红黑树。(是一种自平衡的二叉树)
如何保证元素唯一性呢?
根据比较的返回值是否是0来决定
如何保证元素的排序呢?
两种方式
自然排序(元素具备比较性)
让元素所属的类实现Comparable接口
比较器排序(集合具备比较性)
让集合接收一个Comparator的实现类对象
最新文章
- 求排列组合数C(n,m) φ(゜▽゜*)♪
- UNET学习笔记3 - 网络系统的概念
- Kafka单机环境部署
- [SAP ABAP开发技术总结]将文件存储到数据库表中,并可发送邮件
- 存储过程的参数问题与C#中的调用
- POJ-3522 Slim Span(最小生成树)
- 自学Python5.1-模块简介
- 织梦DEDE网站后台如何上传附件
- 如何给PDF文件制作书签
- TCP聊天工具的实现
- [node.js] fs.renameSync()报错
- SV processses
- jsp标签之jsp:setProperty用法
- Samsung_tiny4412(驱动笔记06)----list_head,proc file system,GPIO,ioremap
- Problem1-Project Euler
- HTML5 的新特性以及新标签的浏览器兼容问题
- 【ssh免登录】设置集群环境ssh免登录步骤
- Redhat安装python环境(readline模块)
- MySQL常用:Got a packet bigger than 'max_allowed_packet' bytes &; MySQL开远程服务
- model.find(options)
热门文章
- 【HDOJ】1074 Doing Homework
- tlplayer,wzplayer支持wince,winphone,windows8 for arm
- 放在jsp头部的代码
- org.apache.hadoop.io.LongWritable cannot be cast to org.apache.hadoop.io.Text
- git引用^和~的区别
- 第4章 类型基础 -- 4.1 所有类型都从System.Object派生
- puppet案例
- KMP学习总结
- 坑爹的IE quirk模式【转】
- Sql FAQ