Java集合总结---Xmind思维导图

 1由来
       

         Java是面向对象的语言,我们在编程的时候自然需要存储对象的容器,数组可以满足这个需求,但是数组初始化时长度是固定的,但是我们往往需要一个长度可变化的容器,因此,集合出现了。

2集合与数组的区别


(1)长度区别:集合长度可变,数组长度不可变

(2)内容区别:集合可存储不同类型元素,数组存储只可单一类型元素

(3)元素区别:集合只能存储引用类型元素,数组可存储引用类型,也可存储基本类型

 3.集合概述

Java集合要从两大接口说起,一为Collection接口,二为Map接口,它们是同一个层次的。

Collection接口被List接口和Set接口继承;

List接口有三个实现类:ArrayList,LinkedList,Vector;

Set接口被HashSet类实现,被SortedSet接口继承,同时TreeSet类实现SortedSet接口,LinkedHashSet类继承HashSet类;

Map接口有两个实现类,HashMap,HashTable。


3.1Collection接口(单列集合)


Collection接口是单列集合的最顶层接口,定义了一些通用的方法。

add(E e)添加元素;  clear()清空元素;  remove(E e)移除元素;  size()元素数量;

toArray()集合转数组;  contains(E e)判断元素是否存在;  isEmpty()判断集合是否为空;

4. List系列集合特点

  1.   ArrayList、LinekdList :有序,可重复,有索引。
  2. 有序:存储和取出的元素顺序一致
  3. 有索引:可以通过索引操作元素
  4. 可重复:存储的元素可以重复

List集合特有方法

  1. List集合因为支持索引,所以多了很多索引操作的独特api,其他Collection的功能List也都继承了。

List的实现类的底层原理

  1.  ArrayList底层是基于数组实现的,根据查询元素快,增删相对慢。
  2. LinkedList底层基于双链表实现的,查询元素慢,增删首尾元素是非常快的。

4.1 LinkedList的特点

  1. 底层数据结构是双链表,查询慢,首尾操作的速度是极快的,所以多了很多首尾操作的特有API。

4.2 LinkedList集合的特有功能

5. Set系列集系概述

5.1 Set系列集合特点

  1. 无序:存取顺序不一致
  2. 不重复:可以去除重复
  3. 无索引:没有带索引的方法,所以不能使用普通for循环遍历,也不能通过索引来获取元素。

5.2 Set集合实现类特点

  1. HashSet : 无序、不重复、无索引。
  2. LinkedHashSet:有序、不重复、无索引。
  3. TreeSet:排序、不重复、无索引。

Set集合的功能上基本上与Collection的API一致。

5.3 HashSet元素无序的底层原理:哈希表

HashSet底层原理

  1. HashSet集合底层采取哈希表存储的数据。
  2. 哈希表是一种对于增删改查数据性能都较好的结构。

哈希表的组成

  1. JDK8之前的,底层使用数组+链表组成
  2. JDK8开始后,底层采用数组+链表+红黑树组成。

哈希值

  1. 是JDK根据对象的地址,按照某种规则算出来的int类型的数值。

5.4 LinkedHashSet集合概述和特点

  1. 有序、不重复、无索引。
  2. 这里的有序指的是保证存储和取出的元素顺序一致
  3. 原理:底层数据结构是依然哈希表,只是每个元素又额外的多了一个双链表的机制记录存储的顺序。 

6. 实现类:TreeSet

TreeSet集合概述和特点

  1. 不重复、无索引、可排序
  2. 可排序:按照元素的大小默认升序(有小到大)排序。
  3. TreeSet集合底层是基于红黑树的数据结构实现排序的,增删改查性能都较好。
  4. 注意:TreeSet集合是一定要排序的,可以将元素按照指定的规则进行排序。

TreeSet集合默认的规则

  1. 对于数值类型:Integer , Double,官方默认按照大小进行升序排序。
  2. 对于字符串类型:默认按照首字符的编号升序排序。
  3. 对于自定义类型如Student对象,TreeSet无法直接排序。

结论:想要使用TreeSet存储自定义类型,需要制定排序规则

自定义排序规则

两种方式中,关于返回值的规则:

  1. 如果认为第一个元素大于第二个元素返回正整数即可。
  2. 如果认为第一个元素小于第二个元素返回负整数即可。
  3. 如果认为第一个元素等于第二个元素返回0即可,此时Treeset集合只会保留一个元素,认为两者重复。

注意:如果TreeSet集合存储的对象有实现比较规则,集合也自带比较器,默认使用集合自带的比较器排序。

7. Collection体系的特点、使用场景总结

  1. 如果希望元素可以重复,又有索引,索引查询要快?
    1. 用ArrayList集合,基于数组的。(用的最多)

2.  如果希望元素可以重复,又有索引,增删首尾操作快?

    1. 用LinkedList集合,基于链表的。

3.  如果希望增删改查都快,但是元素不重复、无序、无索引。

    1. 用HashSet集合,基于哈希表的。

4.  如果希望增删改查都快,但是元素不重复、有序、无索引。

    1. 用LinkedHashSet集合,基于哈希表和双链表。

5.  如果要对对象进行排序。

    1. 用TreeSet集合,基于红黑树。后续也可以用List集合实现排序。

8. Map集合体系

Map集合的概述

Map集合概述和使用

  1. Map集合是一种双列集合,每个元素包含两个数据。
  2. Map集合的每个元素的格式:key=value(键值对元素)。
  3. Map集合也被称为“键值对集合”。

Map集合整体格式:

  1. Collection集合的格式: [元素1,元素2,元素3..]
  2. Map集合的完整格式:{key1=value1 , key2=value2 , key3=value3 , ...} 

Map集合体系特点

  1. Map集合的特点都是由键决定的。
  2. Map集合的键是无序,不重复的,无索引的,值不做要求(可以重复)。
  3. Map集合后面重复的键对应的值会覆盖前面重复键的值。
  4. Map集合的键值对都可以为null。

Map集合实现类特点

  1. HashMap:元素按照键是无序,不重复,无索引,值不做要求。(与Map体系一致)
  2. LinkedHashMap:元素按照键是有序,不重复,无索引,值不做要求。
  3. TreeMap:元素按照建是排序,不重复,无索引的,值不做要求。

8.1 Map集合的实现类HashMap

HashMap的特点

  1. HashMap是Map里面的一个实现类。特点都是由键决定的:无序、不重复、无索引
  2. 没有额外需要学习的特有方法,直接使用Map里面的方法就可以了。
  3. HashMap跟HashSet底层原理是一模一样的,都是哈希表结构,只是HashMap的每个元素包含两个值而已。

实际上:Set系列集合的底层就是Map实现的,只是Set集合中的元素只要键数据,不要值数据而已。

HashMap的特点和底层原理

  1. 由键决定:无序、不重复、无索引。HashMap底层是哈希表结构的。
  2. 依赖hashCode方法和equals方法保证的唯一。
  3. 如果要存储的是自定义对象,需要重写hashCode和equals方法。
  4. 基于哈希表。增删改查的性能都较好。

LinkedHashMap集合概述和特点

  1. 由键决定:有序、不重复、无索引。
  2. 这里的有序指的是保证存储和取出的元素顺序一致
  3. 原理:底层数据结构是依然哈希表,只是每个键值对元素又额外的多了一个双链表的机制记录存储的顺序。

8.2 Map集合的实现类TreeMap

TreeMap集合概述和特点

  1. 由键决定特性:不重复、无索引、可排序
  2. 可排序:按照键数据的大小默认升序(有小到大)排序。只能对键排序。
  3. 注意:TreeMap集合是一定要排序的,可以默认排序,也可以将键按照指定的规则进行排序
  4. TreeMap跟TreeSet一样底层原理是一样的。

TreeMap集合自定义排序规则有2种

  1. 类实现Comparable接口,重写比较规则。
  2. 集合自定义Comparator比较器对象,重写比较规则。

Map集合实现类特点

  1. HashMap:元素按照键是无序,不重复,无索引,值不做要求,基于哈希表(与Map体系一致)
  2. LinkedHashMap:元素按照键是有序,不重复,无索引,值不做要求,基于哈希表
  3. TreeMap:元素只能按照键排序,不重复,无索引的,值不做要求,可以做排序

 9.集合Xmind思维导图

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
分布式架构 漫谈分布式架构 初识分布式架构与意义 如何把应用从单机扩展到分布式 大型分布式架构演进过程 分布式架构设计 主流架构模型-SOA架构和微服务架构 领域驱动设计及业务驱动规划 分布式架构的基本理论CAP、BASE以及其应用 什么是分布式架构下的高可用设计 构架高性能的分布式架构 构建分布式架构最重要因素 CDN静态文件访问 分布式存储 分布式搜索引擎 应用发布与监控 应用容灾及机房规划 系统动态扩容 分布式架构策略-分而治之 从简到难,从网络通信探究分布式通信原理 基于消息方式的系统间通信 理解通信协议传输过程中的序列化和反序列化机制 基于框架的RPC通信技术 WebService/ApacheCXF RMI/Spring RMI Hession 传统RPC技术在大型分布式架构下面临的问题 分布式架构下的RPC解决方案 Zookeeper 分布式系统的基石 从0开始搭建3个节点额度zookeeper集群 深入分析Zookeeper在disconf配置中心的应用 基于Zookeeper Watcher 核心机制深入源码分析 Zookeeper集群升级、迁移 基于Zookeeper实现分布式服务器动态上下线感知 深入分析Zookeeper Zab协议及选举机制源码解读 Dubbo 使用Dubbo对单一应用服务化改造 Dubbo管理中心及及监控平台安装部署 Dubbo分布式服务模块划分(领域驱动) 基于Dubbo的分布式系统架构实战 Dubbo负载均衡策略分析 Dubbo服务调试之服务只订阅及服务只注册配置 Dubbo服务接口的设计原则(实战经验) Dubbo设计原理及源码分析 基于Dubbo构建大型分布式电商平台实战雏形 Dubbo容错机制及扩展性分析 分布式解决方案 分布式全局ID生成方案 session跨域共享及企业级单点登录解决方案实战 分布式事务解决方案实战 高并发下的服务降级、限流实战 基于分布式架构下分布式锁的解决方案实战 分布式架构实现分布式定时调度 分布式架构-中间件 分布式消息通信 消息中间件在分布式架构中的应用 ActiveMQ ActiveMQ高可用集群企业及部署方案 ActiveMQ P2P及PUB/SUB模式详解 ActiveMQ消息确认及重发策略 ActiveMQ基于Spring完成分布式消息队列实战 Kafka Kafka基于Zookeeper搭建高可用集群实战 kafka消息处理过程剖析 Java客户端实现Kafka生产者与消费者实例 kafka的副本机制及选举原理剖析 基于kafka实现应用日志实时上报统计分析 RabbitMQ 初步认识RabbitMQ及高可用集群部署 详解RabbitMQ消息分发机制及主题消息分发 RabbitMQ消息路由机制分析 RabbitMQ消息确认机制 Redis redis数据结构分析 Redis主从复制原理及无磁盘复制分析 Redis管道模式详解 Redis缓存与数据库一致性问题解决方案 基于redis实现分布式实战 图解Redis中的AOF和RDB持久化策略的原理 redis读写分离架构实践 redis哨兵架构及数据丢失问题分析 redis Cluster数据分布算法之Hash slot redis使用常见问题及性能优化思路 redis高可用及高并发实战 缓存击穿、缓存雪崩预防策略 Redis批量查询优化 Redis高性能集群之Twemproxy of Redis 数据存储 MongoDB NOSQL简介及MongoDB支持的数据类型分析 MongoDB可视化客户端及JavaApi实践 手写基于MongoDB的ORM框架 MongoDB企业级集解决方案 MongoDB聚合、索引及基本执行命令 MongoDB数据分片、转存及恢复策略 MyCat MySQL主从复制及读写分离实战 MySQL+keepalived实现双主高可用方案实践 MySQL高性能解决方案之分库分表 数据库中间件初始Mycat 基于Mycat实习MySQL数据库读写分离 基于Mycat实战之数据库切分策略剖析 Mycat全局表、Er表、分片预警分析 Nginx 基于OpenResty部署应用层Nginx以及Nginx+lua实战 Nginx反向代理服务器及负载均衡服务器配置实战 利用keepalived+Nginx实战Nginx高可用方案 基于Nginx实现访问控制、连接限制 Nginx动静分离实战 Nginx Location ReWrite 等语法配置及原理分析 Nginx提供https服务 基于Nginx+lua完成访问流量实时上报Kafka的实战 Netty 高性能NIO框架 IO 的基本概念、NIO、AIO、BIO深入分析 NIO的核心设计思想 Netty产生的背景及应用场景分析 基于Netty实现的高性能IM聊天 基于Netty实现Dubbo多协议通信支持 Netty无锁化串行设计及高并发处理机制 手写实现多协议RPC框架
Java基础思维导图是一个用Xmind软件制作的图形化思维导图,用于梳理和总结Java编程语言的基础知识和概念。 Java基础思维导图包含了Java语言的核心内容,涵盖了面向对象的基本概念、Java的语法规则、数据类型、流程控制、数组、字符串、异常处理、输入输出等方面的知识点。通过这个思维导图,可以清晰地了解Java的基础知识结构,并且将各个知识点之间的关系和联系展示出来。 在Java基础思维导图中,我们会看到Java语言的特点和优势,例如跨平台性、面向对象、安全性等。然后会详细介绍Java程序的基本结构,包括类、方法、变量等的概念和用法,以及Java的命名规范和注释的使用。 接下来,思维导图会讲解Java的数据类型,包括基本数据类型和引用数据类型的定义和使用方法。然后会介绍Java中的运算符、流程控制和循环结构,以及条件语句和循环语句的使用。 在思维导图的其他分支中,我们还会了解Java中的数组和字符串的使用方法,以及常用的库函数。同时也会学习Java的异常处理机制,包括try-catch语句的使用和异常类的继承关系。 最后,思维导图还会涵盖Java的输入输出和文件操作,包括标准输入输出、文件读写的方法和常用类的使用。 通过Java基础思维导图,我们能够清晰地了解Java编程语言的基础知识和概念,有助于我们系统学习和练习Java编程,提高我们的编程能力。同时,这个导图也可以作为日后查阅的工具,方便我们回顾和复习Java的基础知识。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

钟月一人

码字整理不易,感谢各位大佬支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值