javase集合 温故而知新
复习javase集合
1、为什么要有集合?
数组长度需要在初始化时确定大小,数据结构单一、因此集合出现了
2、数组和集合的区别
区别一:数组既可以存储基本数据类型,又可以存储引用类型,集合只能存储引用类型
区别二:数组在初始化的时候就需要确认大小,集合有默认初始大小和扩容机制
区别三:集合类有丰富的封装方法
UML图
粗边框的是常用的的类,虚线边框是接口

集合的两大接口
Collection 接口
常用方法:
| 方法名 | 说明 | 返回类型 | 参数 |
|---|---|---|---|
| add | 添加元素到末尾 | boolean | 添加的元素对象 |
| addAll | 合并另一个Collection | boolean | 实现了Collection的集合 |
| contains | 检查是否包含某个元素 | boolean | 元素对象 |
| containsAll | 检查是否包含集合 | boolean | 实现了Collection的集合 |
| isEmpty | 集合是否为空 | boolean | 无参 |
| remove | 移除元素 | boolean | 元素对象 |
| removeAll | 移除集合中有另一个集合的元素 | boolean | 实现了Collection的集合 |
| size | 返回集合大小 | int | 无参 |
| toArray | 转换成数组 | [ ] | 无参 |
遍历方式:
- 迭代器 Iterator (需要删除元素时推荐用这个)
- forEach
实现接口:List、Set
List常用方法
| 方法名 | 说明 | 返回类型 | 参数 |
|---|---|---|---|
| add(String item, int index) | 添加元素到指定位置 | void | 索引,元素 |
| addAll(int index, Collection<? extends E> c) | 添加集合到指定位置 | boolean | 索引,集合 |
| get(int index) | 获取值 | 元素 | 索引 |
| indexOf(Object o) | 判断List中是否有这个元素,有返回索引,无返回-1 | int | 元素 |
| listIterator() | 返回List迭代器 | ListIterator | 无参 |
| listIterator(int index) | 返回List迭代器,光标移动到参数索引处 | ListIterator | 索引 |
| remove(int index) | 移除List元素 | 元素 | 索引 |
| set(int index, E element) | 替换元素 | 元素 | 索引,元素 |
| subList(int fromIndex, int toIndex) | 分割List | List | 开始索引,结束索引 |
| retainAll(Collection<?> c) | 仅保留包含在指定集合中的此集合中的元素 | boolean | Collection |
| lastIndexOf(Object o) | 返回此列表中指定元素的最后一个发生的索引,如果没有返回-1 | int | 元素 |
List特有遍历方式:
- get
- List迭代器
List常用实现类
- ArrayList
特点:查找速度快,删除添加元素慢,因为底层使用数组,索引位置变化,大于索引的都要往前移一个,线程不安全 - LinkedList
特点:查找速度慢,删除添加元素速度快,因为底层使用链表,需要从头或者从尾开始一个一个查找,复杂度为O(n),删除添加只需要改变上一个节点的引用即可,线程不安全
Set常用方法
| 方法名 | 说明 | 返回类型 | 参数 |
|---|---|---|---|
| retainAll(Collection<?> c) | 仅保留包含在指定集合中的此集合中的元素 | boolean | Collection |
| ... | ... | ... | ... |
Set特点:
无序,存储元素不可重复,元素必须重写hashCode和equlas方法
Set常用实现类
HashSet
特点:元素完全使用HashMap的key来存储,线程不安全TreeSet
特点:使用红黑树为元素排序,更改默认排序有两种方式- 构造函数中传入Comparator
- 元素实现Comparable
线程不安全
LinkedHashSet
特点:HashSet的子类,使用链表来存储插入的顺序,value是LinkedHashMap的key。需要遍历完全部元素的情况下比HashSet效率高。线程不安全
Map接口
常用方法:
| 方法名 | 说明 | 返回类型 | 参数 |
|---|---|---|---|
| put | 添加 | void | key,value |
| putAll | 合并另一个Map | void | 实现了Map的集合 |
| containsKey | 是否包含key | boolean | key |
| containsValue | 是否包含这个值 | boolean | value |
| keySet | 返回Map所有的key | Set | 无参 |
| values | 返回Map所有的value | Collection | 无参 |
| entrySet | 返回key value | Entry | 无参 |
| remove | 删除 | value | key |
| remove | 如果key和value相匹配则删除 | boolean | key,value |
| size | 返回有多少个元素 | int | 无参 |
| clear | 清除 | void | 无参 |
遍历方式:
- entrySet (最常用 性能好)
- values
- keySet
- Iterator
javase集合 温故而知新的更多相关文章
- JavaSE集合(十)之Map
前面给大家介绍了集合家族中的Collection家族,这一篇给大家分享的是集合中的另一个家族就是Map家族.以前的时候学习Map的时候没有很认真的去学习,我觉得很多东西还是不是很清楚. 这次我将总结的 ...
- JavaSE集合(八)之Map
前面给大家介绍了集合家族中的Collection家族,这一篇给大家分享的是集合中的另一个家族就是Map家族.以前的时候学习Map的时候没有很认真的去学习,我觉得很多东西还是不是很清楚. 这次我将总结的 ...
- JavaSE集合基础总览
Java集合 Java集合,也称之为容器.基本上你写所有的Java程序,都必须要用到一个包.该API基本都位于java.util工具类包中,是JavaSE中的重中之重.简单可以总结为“1136”,分别 ...
- JavaSE| 集合
集合 l Collection 层次结构中的根接口.Collection 表示一组对象,这些对象也称为 collection 的元素.一些 collection 允许有重复的元素,而另一些则不允许. ...
- JavaSE 集合概述
1.对象的存储: 数组(基本数据类型 & 引用数据类型) 集合(引用数据类型) 2.集合框架 Collection 接口: 方法: iterator().toArray(); 迭代器遍历集合 ...
- [javaSE] 集合框架(体系概述)
为什么出现集合类 为了方便对多个对象的操作,对对象进行存储,集合就是存储对象最常用的一种方式 数组和集合的不同 数组是固定长度的,集合是可变长度的 数组可以存储基本数据类型,集合只能存储对象 数组只能 ...
- JavaSE 集合补充点(JDK1.9对集合添加的优化)
通常,我们在代码中创建一个集合(例如,List 或 Set ),并直接用一些元素填充它. 实例化集合,几个 add方法调用,使得代码重复. public class Demo01 { public s ...
- [javaSE] 集合框架(共性方法)
Collection接口的常用方法 add(),添加一个元素 addAll(),添加一组元素 clear(),清空 remove(),移除一个 removeAll(),移除一组 size(),元素个数 ...
- [javaSE] 集合框架(TreeSet)
TreeSet:可以对Set集合中的元素排序,默认按照ascii表排序,二叉树结构 左边叉是小的,右边叉是大的 存储自定义对象 定义一个类Student实现Comparable类,使自定义类具备比较性 ...
随机推荐
- springboot常用的starter有哪些?
spring-boot-starter-web 嵌入tomcat和web开发需要servlet与jsp支持 spring-boot-starter-data-jpa 数据库支持 spring-boot ...
- Oracle数据库 如何根据某个字段名的值去查询存在的表列表
declare v_sql varchar2(1000); data_count number; begin -- OWNER是模式名 tablespace_name是表空间 for cur_tabl ...
- Kafka 高效文件存储设计特点?
Kafka把topic中一个parition大文件分成多个小文件段,通过多个小文件段,就容易定期清除或删除已经消费完文件,减少磁盘占用. 通过索引信息可以快速定位message和确定response的 ...
- 运筹学之"概率"和"累计概率"和"谁随机数"
概率 = 2/50 = 0.2 累计概率 = 上个概率加本次概率 案例1 概率=销量天数 / 天数 = 2 /100 = 0.02 累计概率 = 上个概率加本次概率 = 0.02 +0.03 = 0. ...
- C 语言中 static 的作用
在 C 语言中,static 的字面意思很容易把我们导入歧途,其实它的作用有三条. (1)先来介绍它的第一条也是最重要的一条:隐藏 当我们同时编译多个文件时,所有未加 static 前缀的全局变量和函 ...
- 从零开始画自己的DAG作业依赖图(四)--节点连线优化版
概述 上个版本简单的连线在一些复杂场景,尤其层级比较多,连线跨层级比较多的情况下,会出现线条会穿过矩形的情况,这一讲就是在这个基础上,去优化这个连线. 场景分析 在下面几种情况下,简单版本的画法已经没 ...
- C#和TS/JS的对比学习02:函数与方法
程序本质上,就是由数据和处理数据的方法构成.函数和方法,这两个名词虽然字面不同,但意义上其实没有区别.只是因为它们出现的地方有异,给予了不同的名称,比如在全局环境中,叫函数,在对象或类中,叫方法.而C ...
- MongoDB从bson文件中恢复数据
首先需要到mangodb的安装目录的bin下面找到mongorestore.exe WIN10系统MongoDB安装目录bin文件夹下没有mongorestore.exe 先下载工具 https:/ ...
- Mybatis实现批量删除数据
Mybatis实现批量删除操作 学习内容: 1. 使用 2. 代码实现 2.1 UserMapper.java 接口 2.2 UserMapper.xml 总结: 学习内容: 1. 使用 这里通过动态 ...
- Jenkins 脚本命令行应用总结
Jenkins脚本命令行应用总结 测试环境 Jenkins 2.304 脚本命令行入口 Jenkins主页→系统管理→脚本命令行 遍历项目 例子:获取所有自由风格项目及相关项目信息 def proje ...