欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Java集合类,一张图说清楚!

程序员文章站 2022-11-21 08:17:04
作者:skywang12345 https://www.cnblogs.com/skywang12345/p/3308498.html 2019 03 23 10:32:24 Java集合是java提供的工具包,包含了常用的数据结构: 集合、链表、队列、栈、数组、映射 等。 Java集合工具包位置是 ......

作者:skywang12345

2019-03-23 10:32:24

Java集合类,一张图说清楚!

java集合是java提供的工具包,包含了常用的数据结构:集合、链表、队列、栈、数组、映射等。

java集合工具包位置是java.util.*,java集合主要可以划分为4个部分:

  • list列表

  • set集合

  • map映射

  • 工具类(iterator迭代器、enumeration枚举类、arrays和collections)

java集合工具包框架图(如下):

Java集合类,一张图说清楚!

大致说明:

看上面的框架图,先抓住它的主干,即collection和map

一、collection是一个接口,是高度抽象出来的集合,它包含了集合的基本操作和属性。

collection包含了list和set两大分支。

list是一个有序的队列,每一个元素都有它的索引。第一个元素的索引值是0。
list的实现类有linkedlist, arraylist, vector, stack。

set是一个不允许有重复元素的集合。set的实现类有hastset和treeset。hashset依赖于hashmap,它实际上是通过hashmap实现的;treeset依赖于treemap,它实际上是通过treemap实现的。

二、map是一个映射接口,即key-value键值对。map中的每一个元素包含“一个key”和“key对应的value”。

abstractmap是个抽象类,它实现了map接口中的大部分api。而hashmap,treemap,weakhashmap都是继承于abstractmap。

hashtable虽然继承于dictionary,但它实现了map接口。

接下来,再看iterator。它是遍历集合的工具,即我们通常通过iterator迭代器来遍历集合。

我们说collection依赖于iterator,是因为collection的实现类都要实现iterator()函数,返回一个iterator对象。listiterator是专门为遍历list而存在的。

再看enumeration,它是jdk 1.0引入的抽象类。作用和iterator一样,也是遍历集合;但是enumeration的功能要比iterator少。在上面的框图中,enumeration只能在hashtable, vector, stack中使用。

最后,看arrays和collections。它们是操作数组、集合的两个工具类。

有了上面的整体框架之后,我们接下来可以对每个类分别进行分析了。

关注java技术栈微信公众号,在后台回复关键字:java,可以获取更多栈长整理的java技术干货。

推荐去我的博客阅读更多:

1.java jvm、集合、多线程、新特性系列教程

2.spring mvc、spring boot、spring cloud 系列教程

3.maven、git、eclipse、intellij idea 系列工具教程

4.java、后端、架构、阿里巴巴等大厂最新面试题

觉得不错,别忘了点赞+转发哦!