复习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常用实现类
  1. ArrayList

    特点:查找速度快,删除添加元素慢,因为底层使用数组,索引位置变化,大于索引的都要往前移一个,线程不安全
  2. LinkedList

    特点:查找速度慢,删除添加元素速度快,因为底层使用链表,需要从头或者从尾开始一个一个查找,复杂度为O(n),删除添加只需要改变上一个节点的引用即可,线程不安全

Set常用方法

方法名 说明 返回类型 参数
retainAll(Collection<?> c) 仅保留包含在指定集合中的此集合中的元素 boolean Collection
... ... ... ...
Set特点:

无序,存储元素不可重复,元素必须重写hashCode和equlas方法

Set常用实现类
  1. HashSet

    特点:元素完全使用HashMap的key来存储,线程不安全

  2. TreeSet

    特点:使用红黑树为元素排序,更改默认排序有两种方式

    • 构造函数中传入Comparator
    • 元素实现Comparable

    线程不安全

  3. 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集合 温故而知新的更多相关文章

  1. JavaSE集合(十)之Map

    前面给大家介绍了集合家族中的Collection家族,这一篇给大家分享的是集合中的另一个家族就是Map家族.以前的时候学习Map的时候没有很认真的去学习,我觉得很多东西还是不是很清楚. 这次我将总结的 ...

  2. JavaSE集合(八)之Map

    前面给大家介绍了集合家族中的Collection家族,这一篇给大家分享的是集合中的另一个家族就是Map家族.以前的时候学习Map的时候没有很认真的去学习,我觉得很多东西还是不是很清楚. 这次我将总结的 ...

  3. JavaSE集合基础总览

    Java集合 Java集合,也称之为容器.基本上你写所有的Java程序,都必须要用到一个包.该API基本都位于java.util工具类包中,是JavaSE中的重中之重.简单可以总结为“1136”,分别 ...

  4. JavaSE| 集合

    集合 l  Collection 层次结构中的根接口.Collection 表示一组对象,这些对象也称为 collection 的元素.一些 collection 允许有重复的元素,而另一些则不允许. ...

  5. JavaSE 集合概述

    1.对象的存储: 数组(基本数据类型 & 引用数据类型) 集合(引用数据类型) 2.集合框架 Collection 接口: 方法: iterator().toArray();  迭代器遍历集合 ...

  6. [javaSE] 集合框架(体系概述)

    为什么出现集合类 为了方便对多个对象的操作,对对象进行存储,集合就是存储对象最常用的一种方式 数组和集合的不同 数组是固定长度的,集合是可变长度的 数组可以存储基本数据类型,集合只能存储对象 数组只能 ...

  7. JavaSE 集合补充点(JDK1.9对集合添加的优化)

    通常,我们在代码中创建一个集合(例如,List 或 Set ),并直接用一些元素填充它. 实例化集合,几个 add方法调用,使得代码重复. public class Demo01 { public s ...

  8. [javaSE] 集合框架(共性方法)

    Collection接口的常用方法 add(),添加一个元素 addAll(),添加一组元素 clear(),清空 remove(),移除一个 removeAll(),移除一组 size(),元素个数 ...

  9. [javaSE] 集合框架(TreeSet)

    TreeSet:可以对Set集合中的元素排序,默认按照ascii表排序,二叉树结构 左边叉是小的,右边叉是大的 存储自定义对象 定义一个类Student实现Comparable类,使自定义类具备比较性 ...

随机推荐

  1. JVM的垃圾回收算法有哪些

    常用的垃圾回收算法有如下四种:标记-清除.复制.标记-整理和分代收集. 标记-清除算法从算法的名称上可以看出,这个算法分为两部分,标记和清除.首先标记出所有需要被回收的对象,然后在标记完成后统一回收掉 ...

  2. C# winform自己的窗体不抢夺其他窗体的光标

    在你的form里加入: protected override CreateParams CreateParams { get { var result = base.CreateParams; ; r ...

  3. JDBC 中如何进行事务处理?

    Connection 提供了事务处理的方法,通过调用 setAutoCommit(false)可以设置 手动提交事务:当事务完成后用 commit()显式提交事务:如果在事务处理过程中 发生异常则通过 ...

  4. 使用 Spring 框架的好处是什么?

    轻量:Spring 是轻量的,基本的版本大约 2MB.控制反转:Spring 通过控制反转实现了松散耦合,对象们给出它们的依 赖,而不是创建或查找依赖的对象们.面向切面的编程(AOP):Spring ...

  5. 使用 Docker, 7 个命令部署一个 Mesos 集群

    这个教程将给你展示怎样使用 Docker 容器提供一个单节点的 Mesos 集群(未来的一篇文章将展示怎样很容易的扩展这个到多个节点或者是见底部更新).这意味着你可以使用 7 个命令启动整个集群!不需 ...

  6. TOP 10 开源的推荐系统简介

      最 近这两年推荐系统特别火,本文搜集整理了一些比较好的开源推荐系统,即有轻量级的适用于做研究的SVDFeature.LibMF.LibFM等,也有重 量级的适用于工业系统的 Mahout.Oryx ...

  7. 几种常见布局的flex写法

    flex布局目前基本上兼容主流的浏览器,且实现方式简单.我整理了flex的一些知识点,并且总结归纳了几种常见布局的flex写法 ​flex基础知识点 flex-grow和flex-shrink相关计算 ...

  8. anijs 一个小巧的动画库

    很多时候我意识到前端已近变成写h5宣传页面 我不知道是可悲 还是生活的必然 小问题 使用css animation和js animation api制作动画是目前比较流行的做法 但是最后很多人的代码就 ...

  9. Kurento安装与入门08——Group Call

    Group Call 本示例展示了一个视频聊天室的功能,不同的聊天室之间互相隔离. 官网文档 Group Call 首先从github上获取代码(如果已经获取可以跳过,获取的代码已经包括后面的示例代码 ...

  10. 移动端的vw px rem之间换算

    一.vw px rem em是什么 1.vw:就是相对视口宽度(Viewport Width).1vw = 1% * 视口宽度.也就是说,一个视口就是100vw. 2.px:px应该是在css中使用最 ...