美文网首页
Java容器类框架概述

Java容器类框架概述

作者: wustor | 来源:发表于2017-09-25 20:29 被阅读223次

Java容器类概述
Java容器有两类框架,一类是Collection,一类是Map,下面通过两张图片来分析一下这两种容器,之所以说是容器,是因为Map不属于Collection,而是一个单独的接口

Collection接口

Collection接口

思维导图中的标注黑体的是比较常见的集合,主要用Arraylist,LinkedList,HashSet,Collection继承了Iterable接口

Collection的内部方法

Collection继承关系 Collection的内部方法

这些方法都很常见,根据名字基本上都能知道具体的作用,所以但凡是实现了Collection的接口都能够使用这些方法。

Collection的实现类

List

源码的注释

  • An ordered collection (also known as a <i>sequence</i>). The user of this
    interface has precise control over where in the list each element is
    inserted. The user can access elements by their integer index (position in the list), and search for elements in the list.
  • 意思是说List是一个有序的Collection,这个接口的使用者能够准确的控制他所插入的每一个元素,使用者也能够根据他们的整数索引在List中查找元素。

常见的List的实现有ArrayList,LinkedList

Set

源码的注释

  • A collection that contains no duplicate elements. More formally, sets
    contain no pair of elements <code>e1</code> and <code>e2</code> such that
    <code>e1.equals(e2)</code>, and at most one null element. As implied by
    its name, this interface models the mathematical <i>set</i> abstraction.
  • 一个没有重复元素的集合,并且,set也不能存放两个用equals方法比较相等的元素,最多可以放入一个null值。就像他的名字一样,这个接口模拟了数学中的集合。

常见的set集合有HastSet

Queue

源码的注释

  • A collection designed for holding elements prior to processing.
    Besides basic operations,queues provide additional insertion, extraction, and inspection
    operations. Each of these methods exists in two forms: one throws
    an exception if the operation fails, the other returns a special
    value (either {@code null} or {@code false}, depending on the
    operation). The latter form of the insert operation is designed
    specifically for use with capacity-restricted {@code Queue}
    implementations; in most implementations, insert operations cannot
    fail.
  • 一种被设计用来可以放置优先级元素的集合,除了基本的Collection操作以外,queue还提供另外的插入,提取和检查操作。每一个方法的执行结构存在两种形式:一种是执行失败会跑出一种异常,另外一种是返回特定的结果:null值或者false,具体取决于操作的结果。后一种插入操作的返回形式是针对特定容量的实现,在queue的大多实现里,插入操作是不会失败的。

常见的queue的实现有BlockingQueue跟PriorityQueue

Comparable跟Comparator

这是Java在集合中提供的两个接口,主要用来比较两个元素和进行排序,如果只是比较相同的两个类,则都可以实现,不过还是有些区别:

  • Comparator是在类的外部进行排序,Comparable是在类的内部进行排序
  • Comparator比较适合对于多个类进行排序,只需要实现一个Comparator就可以,Comparable则需要在每个类中实现Comparable接口

Collection的工具类

Collection提供了两个工具类,一个是Collections,一个是Arrays

Collections
Collections提供的方法
Arrays
Arrays提供的方法

Java源码的命名都比较规范,通过名字基本上能看出用法,有些即时不能够看出来用法,点击去看一下注释,或者写个小demo也能知道,通过这两个工具类,实际上可以简化我们队集合跟数组的操作,例如排序,同步,求最大值,最小值等,感兴趣的可以看一下,文章图片比较多,是因为觉得一图胜千言,所以代码就尽量少贴喽。

Map接口

Map接口

思维导图中的标注黑体的是比较常见的集合,主要有HashedMap,LinkedHashMap,TreeMap。

Map的内部方法

Map的内部方法

源码注释:

  • An object that maps keys to values. A map cannot contain duplicate keys; each key can map to at most one value.
  • 一个能够将key应射成value的Objec,Map不能有重复的key,每个key最多只能对应一个value

Map的实现类

比较常见的是HashMap,LinkedHashMap

总结

上面大题就是Java的整个容器框架,分析地比较简单,接下来主要是分析下常见的Java容器类的实现类,毕竟整个源码比较复杂,不能面面俱到。主要是通过思维导图和IDEA生成的UML来进行分析,这样会显得整个思路比较清晰,不至于一头钻进源码,只见树木,不见森林。

相关文章

  • Java容器类框架概述

    Java容器类概述Java容器有两类框架,一类是Collection,一类是Map,下面通过两张图片来分析一下这两...

  • 3.4 Java 中的集合框架(上)(常用工具类)

    1、Java中的集合框架概述 集合框架、 概念与作用Java中的集合类:是一种工具类,就像是容器,存储任意数量的具...

  • 数据结构--容器汇总(java & Android)

    数据结构与算法容器概览(java)容器类框架分析(1)(java)ArrayList源码分析容器类框架分析(2)(...

  • Java集合框架详解

    一、Java集合框架概述 集合可以看作是一种容器,用来存储对象信息。所有集合类都位于java.util包下,但支持...

  • java集合框架学习笔记

    java容器类类库的用途是保存对象。Java集合框架中主要有两种容器:Collection和Map。集合框架包括以...

  • JavaSE集合类

    JavaSE集合类 概述 Java中集合类概述Java中数组与集合的比较Java中集合框架层次结构 Collect...

  • JAVA并发容器框架

    概述 JAVA容器是JAVA实现基本数据结构的地方,分为两类:非并发容器和并发容器。非并发容器在java.util...

  • JAVA非并发容器框架

    概述 JAVA容器是JAVA实现基本数据结构的地方,分为两类:非并发容器和并发容器。非并发容器在java.util...

  • Java集合框架01-框架总览

    本节摘要:从整体概述Java集合框架 一、Java集合框架架构图 Java集合框架是Java为开发者提供的工具类,...

  • Java自学-集合框架 Collections

    Java集合框架 工具类Collections Collections是一个类,容器的工具类,就如同Arrays是...

网友评论

      本文标题:Java容器类框架概述

      本文链接:https://www.haomeiwen.com/subject/tnndextx.html