集合框架

集合框架如图所示

Java集合是Java提供的工具包,主要包括常用的数据结构,包括:集合、链表、队列、栈、数组、映射等。
集合的工具包位置是java.util.*

集合主要可以分为五类:

  • List列表;
  • Set集合;
  • Map映射;
  • Queue队列
  • 工具类(Iterator迭代器、Enumeration枚举类、Arrays和Collections)。

其中也可以主要分为Colleciton和Map两大类。

Collection

它是一个接口,是高度抽象出来的集合,它包含了集合的基本操作:添加、删除、清空、遍历(读取)、是否为空、获取大小、是否保护某元素等等。
定义:

public interface Collection<E> extends Iterable<E> {}

Collection是一个接口,下面又有Queue、List、Set三个分支。其中Queue和List是有序可重复的,Set是无序不重复的。而Queue和List的本质是一样的,都是列表,不过抽象出的接口不同罢了。

再看接口下面,为了实现代码的复用,又抽象出了AbstractCollection、AbstractList、AbstractSet几个抽象类。

最底层就是具体的实现类了。

Collection还实现了Iterator接口,返回一个iterator()函数,这样可以使得Collection接口下的实现类都能被迭代器进行一个迭代遍历。

List

定义:
List是一个继承于Collection的接口,即List是集合中的一种。List是有序的队列,List中的每一个元素都有一个索引;第一个元素的索引值是0,往后的元素的索引值依次+1。允许有重复元素。

public interface List<E> extends Collection<E> {}

Set

定义:
Set是一个继承于Collection的接口,即Set也是集合中的一种。Set是没有重复元素的集合,无序。

public interface Set<E> extends Collection<E> {}

AbstractCollection

定义:
AbstractCollection是一个抽象类,它实现了Collection中除iterator()和size()之外的函数。这样下面的list或者set继承了之后就不需要再重复实现一些代码了。

public abstract class AbstractCollection<E> implements Collection<E> {}

AbstractList

定义:
AbstractList是一个继承于AbstractCollection,并且实现List接口的抽象类。它实现了List中除size()、get(int location)之外的函数。它还实现了iterator接口。

public abstract class AbstractList<E> extends AbstractCollection<E> implements List<E> {}

AbstractSet

定义:
AbstractSet是一个继承于AbstractCollection,并且实现Set接口的抽象类。由于Set接口和Collection接口中的API完全一样,Set也就没有自己单独的API。实现Set中大部分函数。

public abstract class AbstractSet<E> extends AbstractCollection<E> implements Set<E> {}

Iterator

定义:
Iterator是一个接口,它是集合的迭代器。集合可以通过Iterator去遍历集合中的元素。Iterator提供的API接口,包括:是否存在下一个元素、获取下一个元素、删除当前元素。

public interface Iterator<E> {}

ListIterator

定义:
ListIterator是一个继承于Iterator的接口,它是队列迭代器。专门用于便利List,能提供向前/向后遍历。相比于Iterator,它新增了添加、是否存在上一个元素、获取上一个元素等等API接口。

public interface ListIterator<E> extends Iterator<E> {}

Map

Map就是映射接口,实现Map接口的容器都是需要存储键值对的。基本操作就是存储、获取、删除、查找、获取容量大小等,这就有点像数据库。

定义:

public interface Map<K,V> { }

特点:

  • 键不能重复,一个键只能映射一个值。
  • 有些实现类能保持顺序,有些不能。

Map.Entry

interface Entry<K,V> { }

Map的内部接口,用来定义键值对,可以通过entrySet()获取键值对的集合。

AbstractMap

public abstract class AbstractMap<K,V> implements Map<K,V> {}

Map接口的主要实现抽象类,减少后面具体实现类的重复代码。

SortedMap

public interface SortedMap<K,V> extends Map<K,V> { }

用于规范有序键值对Map的接口,可以进行自然排序和实现Comparable接口的元素的排序。

NavigableMap

public interface NavigableMap<K,V> extends SortedMap<K,V> { }

继承与SortedMap的接口,它是一个可导航的键值对集合,具有了为给定搜索目标报告最接近匹配项的导航方法。

所谓可导航,就是可以获取对应范围的键值对,可以获取键集。

Dictionary

public abstract class Dictionary<K,V> {}

是JDK 1.0定义的键值对的接口,它也包括了操作键值对的基本函数。

Set

  • Set 是继承于Collection的接口。它是一个不允许有重复元素的集合。
  • 有两个实现类
    • HashSet依赖于HashMap,它实际上是通过HashMap实现的。HashSet中的元素是无序的。
    • TreeSet依赖于TreeMap,它实际上是通过TreeMap实现的。TreeSet中的元素是有序的。

AbstractSet

public abstract class AbstractSet<E> extends AbstractCollection<E> implements Set<E> {}

AbstractSet 是一个抽象类,它继承于AbstractCollection,AbstractCollection实现了Set中的绝大部分函数,为Set的实现类提供了便利。

其中实现了equals、hashCode、removeAll函数。

SortedSet

public interface SortedSet<E> extends Set<E> {}

SortedSet是继承Set的接口,多了几个有序读取的接口函数,还有比较器函数。

NavigableSet

public interface NavigableSet<E> extends SortedSet<E> {}

继承于SortSet,多了几个有序的读取函数,和有序的集合获取函数。

Java集合源码分析(一)——集合框架的更多相关文章

  1. Java 集合源码分析(一)HashMap

    目录 Java 集合源码分析(一)HashMap 1. 概要 2. JDK 7 的 HashMap 3. JDK 1.8 的 HashMap 4. Hashtable 5. JDK 1.7 的 Con ...

  2. java集合源码分析(三):ArrayList

    概述 在前文:java集合源码分析(二):List与AbstractList 和 java集合源码分析(一):Collection 与 AbstractCollection 中,我们大致了解了从 Co ...

  3. java集合源码分析(六):HashMap

    概述 HashMap 是 Map 接口下一个线程不安全的,基于哈希表的实现类.由于他解决哈希冲突的方式是分离链表法,也就是拉链法,因此他的数据结构是数组+链表,在 JDK8 以后,当哈希冲突严重时,H ...

  4. [源码分析] 定时任务调度框架 Quartz 之 故障切换

    [源码分析] 定时任务调度框架 Quartz 之 故障切换 目录 [源码分析] 定时任务调度框架 Quartz 之 故障切换 0x00 摘要 0x01 基础概念 1.1 分布式 1.1.1 功能方面 ...

  5. Java Reference 源码分析

    @(Java)[Reference] Java Reference 源码分析 Reference对象封装了其它对象的引用,可以和普通的对象一样操作,在一定的限制条件下,支持和垃圾收集器的交互.即可以使 ...

  6. Java集合源码分析(六)TreeSet<E>

    TreeSet简介 TreeSet 是一个有序的集合,它的作用是提供有序的Set集合.它继承于AbstractSet抽象类,实现了NavigableSet<E>, Cloneable, j ...

  7. Java集合源码分析(五)HashSet<E>

    HashSet简介 HashSet实现Set接口,由哈希表(实际上是一个HashMap实例)支持.它不保证set 的迭代顺序:特别是它不保证该顺序恒久不变.此类允许使用null元素. HashSet源 ...

  8. Java集合源码分析(四)Vector<E>

    Vector<E>简介 Vector也是基于数组实现的,是一个动态数组,其容量能自动增长. Vector是JDK1.0引入了,它的很多实现方法都加入了同步语句,因此是线程安全的(其实也只是 ...

  9. Java集合源码分析(三)LinkedList

    LinkedList简介 LinkedList是基于双向循环链表(从源码中可以很容易看出)实现的,除了可以当做链表来操作外,它还可以当做栈.队列和双端队列来使用. LinkedList同样是非线程安全 ...

  10. Java集合源码分析(二)ArrayList

    ArrayList简介 ArrayList是基于数组实现的,是一个动态数组,其容量能自动增长,类似于C语言中的动态申请内存,动态增长内存. ArrayList不是线程安全的,只能用在单线程环境下,多线 ...

随机推荐

  1. wait函数与waitpid函数(僵尸进程)

    当子进程退出时,内核会向父进程发送SIGCHLD信号,子进程的退出是个异步事件(子进程可以在父进程运行的任何时刻终止) 子进程退出时,内核将子进程置为僵尸状态,这个进程称为僵尸进程.它只保留最小的一些 ...

  2. shell编程之算术扩展(引号、命令替换、算术扩展)

    1.单引号 .双引号.反引号的区别 单引号:忽略所有特殊字符 双引号:忽略大部分特殊字符($  `等字符除外) [root@tlinux shell]# echo '*' * [root@tlinux ...

  3. Fiddler的一系列学习瞎记3

    Http: 不安全.可以很容易被拦截,或者其他的嗅探工具发现.怎么样做到安全?起码一下两点: 1.浏览器和we服务器之间的内容应该只有浏览器和web服务器能看到通信内容. 2.Http请求和Http的 ...

  4. Flink处理函数实战之三:KeyedProcessFunction类

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  5. 存储型跨站获取COOKIE漏洞复现

    一.漏洞描述 获取网站cookie 二.漏洞原理 1.服务器后台写入PHP代码 $cookie = $_GET['cookie']; if($cookie){ echo ($cookie); $log ...

  6. Java Web 会话技术总结

    会话技术 会话概念 一次会话中包含多次请求和响应. 一次会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开为止,一次会话结束. 会话的功能 在一次会话的范围内的多次请求间,共享数据. 会 ...

  7. FL Studio 插件使用技巧——Fruity Reeverb 2(下)

    了解大教堂声场的特点 上节教程中我们说到,混响具有营造空间感的作用.当我们想要在FL Studio软件中用Fruity Reeverb 2 插件有目标地模仿一个特定空间的环境时,我们需要充分了解该空间 ...

  8. pytest和unittest中参数化如何做

    参数化应用场景,一个场景的用例会用到多条数据来进行验证,比如登录功能会用到正确的用户名.密码登录,错误的用户名.正确的密码,正确的用户名.错误的密码等等来进行测试,这时就可以用到框架中的参数化,来便捷 ...

  9. Java基础教程——反射机制

    Java反射机制 Java反射机制是Java语言的一个重要特性,使得Java语言具备"动态性": 在运行时获取任意一个对象所属的类的相关信息; 在运行时构造任意一个类的对象: 在运 ...

  10. 使C语言实现面向对象的三个要素,你掌握了吗?