Java之集合框架汇总分析

一:框架图

二:框架分析

(0)点线框表示接口,实线框表示具体的类。

(1)常用的List、Set、Queue、Map都属于集合类。前三个都是继承自Collection,但是Map不是。

(2)List不仅可以生成普通的Iterator(因为继承自Collection),还能生成ListIterator。

(3)常用的类ArrayList、LinkedList、HashSet、HashMap。这几个类请好好研读JDK源码

(4)其它需要好好掌握的容器:CopyOnWriteArrayList、TreeSet、TreeMap、HashTable、LinkedHashMap、ConcurrentHashMap。

三:容器分析

(1)ArrayList

(1.1)底层使用一个Object数组来实现。get和set操作基于这个数组。

(1.2)List在遍历的时候,如果被修改了会抛出java.util.ConcurrentModificationException异常。

(2)LinkedList

底层采用采用一个first和last的Node<E>节点,通过链表来实现。

(3)Hashmap

(3.1)底层采用Node<K,V>[] table 的数组+链表的形式来实现。

(3.2)key和value都可以为NULL。

(3.3)是线程不安全的。

(4)HashSet

底层采用HashMap来实现。

其中value使用private static final Object PRESENT = new Object()来表示。

(5)CopyOnWriteArrayList

(5.1)底层数据结构

final transient ReentrantLock lock = new ReentrantLock();

private transient volatile Object[] array;

(5.2)基本操作

get(int index)操作直接取数组对应的元素。

set(int index, E element) 操作按如下步骤:

  • 调用lock.lock()
  • 取index处对应的元素oldValue
  • 如果oldValue和element不等,则复制原数组,然后设置index处的值为element,最后原数组指向新数组。
  • 如果相等,原数组还是指向原数组。
  • lock.unlock()

(6)TreeMap

(6.1)继承自AbstractMap<K,V>,实现了NavigableMap<K,V>

(6.2)底层使用红黑树实现,有一个比较器来比较元素的排列顺序,元素是有序的。

(6.3)key不能为NULL,value可以为NULL。key不能为null是因为key之间需要比较大小。

(7)TreeSet

底层使用TreeMap来实现。

(8)HashTable

(8.1)put和get方法都用synchronized修饰

(8.2)底层是Entry<?,?>[] table,也是数组+链表的形式来实现。

(8.3)put操作中会检查value是否为null,是则抛出NullPointerException。put操作中会调用key.hashCode(),所以key不能为null。综上,key和value都不能为null。

(9)LinkedHashMap

(9.1)继承自HashMap,增加了一个额外的双向链表维护key插入和访问的有序性。

(9.2)内部的Entry<K,V>基础自HashMap.Node<K,V>,并增加了两个节点: Entry<K,V> before, after。

(9.3)包含LinkedHashMap.Entry<K,V> head和LinkedHashMap.Entry<K,V> tail。

(9.4)key和value都可以为null。

(10)ConcurrentHashMap

(10.1)JDK6和JDK7中采用分段锁的设计。采用segment数组和HashEntry数组的数据结构组成,segment是一种可重入锁ReentrantLock。默认segment数组大小为16。

(10.2)是否需要扩容:在插入元素之前,会判断Segment里的HashEntry数组是否超过阈值(threshold)。如果超过阀值,则需要进行扩容。而HashMap是put后才判断。

(10.3)如何扩容:ConcurrentHashMap扩容不是针对整个容器,而是针对Segment。新创建的HashEntry数组大小是原来的两倍。

(10.4)put操作步骤

  • 为key做Hash运算,得到hash值。
  • 通过hash值,定位到具体的Segment对象
  • 获取可重入锁
  • 再次通过hash值,定位到Segment中HashEntry数组的具体位置。
  • 插入或覆盖HashEntry对象。
  • 释放锁。

(10.5)JDK8之后使用CAS算法

原文地址:https://www.cnblogs.com/fdzfd/p/9219082.html

时间: 2024-10-08 14:28:11

Java之集合框架汇总分析的相关文章

java的集合框架最全详解

java的集合框架最全详解(图) 前言:数据结构对程序设计有着深远的影响,在面向过程的C语言中,数据库结构用struct来描述,而在面向对象的编程中,数据结构是用类来描述的,并且包含有对该数据结构操作的方法. 在Java语言中,Java语言的设计者对常用的数据结构和算法做了一些规范(接口)和实现(具体实现接口的类).所有抽象出来的数据结构和操作(算法)统称为Java集合框架(JavaCollectionFramework). Java程序员在具体应用时,不必考虑数据结构和算法实现细节,只需要用这

Java的集合框架最全详解(图)

纯个人整理,如有错误请指正. java的集合框架最全详解(图) 前言:数据结构对程序设计有着深远的影响,在面向过程的C语言中,数据库结构用struct来描述,而在面向对象的编程中,数据结构是用类来描述的,并且包含有对该数据结构操作的方法. 在Java语言中,Java语言的设计者对常用的数据结构和算法做了一些规范(接口)和实现(具体实现接口的类).所有抽象出来的数据结构和操作(算法)统称为Java集合框架(JavaCollectionFramework). Java程序员在具体应用时,不必考虑数据

java的集合框架之一

java是一套很成熟的东西,很多商用的东西都喜欢用它,用的人多,稳定.不过一般也不怎么说起它,因为太常见了,私下里说,写java应用层得就像农民工,每一处都是搭积木,根据设计师的东西如何优雅地搭好积木,当然美其名曰,论农民工搭积木的艺术修养.不难,但是东西很多,经验在里面是一个相当重要的东西.以上纯属每天扯淡,笑看即可,毕竟我目前就是个渣java程序员. java的集合框架以collection接口当作基础,这个接口定义了基本框架,包括size.hashcode.iterator.add.add

java.util 集合框架集合

java的集合框架为程序提供了一种处理对象组的标准方式.设计了一系列标准泛型接口: ⑴Collection ()接口,扩展了Iterable接口,位于集合层次结构的顶部,因此所有的集合都实现Collection接口,并提供了iterator()方法来返回一个迭代器.用add()方法添加对象,remove方法()删除元素,clear()删除集合所有元素(size=0),contains()方法查看集合是否包含对象,toArray()方法返回集合元素数组,equals()方法比较两个集合是否相等,s

Java中集合框架,Collection接口、Set接口、List接口、Map接口,已经常用的它们的实现类,简单的JDK源码分析底层实现

(一)集合框架: Java语言的设计者对常用的数据结构和算法做了一些规范(接口)和实现(实现接口的类).所有抽象出来的数据结构和操作(算法)统称为集合框架. 程序员在具体应用的时候,不必考虑数据结构和算法实现细节,只需要用这些类创建一些对象,然后直接应用就可以了,这样就大大提高了编程效率. (二)集合框架包含的内容: (三)集合框架的接口(规范)   Collection接口:存储一组不唯一,无序的对象 List接口:存储一组不唯一,有序的对象 Set接口:存储一组唯一,无序的对象 Map接口:

java之集合框架

1.集合的由来: 我们学习的是面向对象的语言.而面向对象语言对事物的描述是通过对象体现的.为了方便对多个对象进行操作,我们就必须把多个对象进行存储.而要想存储多个对象,就不能是一个基本的变量,而应该是一个容器类型的变量.在我们目前所学过的知识里面,有哪些是容器类型的呢?数组和StringBuffer.但是StringBuffer的结果是一个字符串, 不一定符合我们的要求,所以我们只能选择数组,这就是对象数组.而对象数组又不能适应变化的需求.因为数组的长度是固定的.这个时候,为了适应变化的需求,j

java中级——集合框架【1】

集合框架----ArrayList 引子:我们先来看看传统数组的用法 写一个Hero对象类 package cn.jse.t1; public class Hero { public String name; public float hp; public int damage; public Hero(){} //增加一个初始化name的构造方法 public Hero(String name){ this.name=name; } //重写一个toString 方法 public Strin

【38】java的集合框架(容器框架)

Collection接口 Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Elements).一些 Collection允许相同的元素而另一些不行.一些能排序而另一些不行.Java SDK不提供直接继承自Collection的类,Java SDK提供的类都是继承自Collection的"子接口"如List和Set. 所有实现Collection接口的类都必须提供两个标准的构造函数:无参数的构造函数用于创建一个空的Col

Java:集合框架的工具类

集合框架的工具类 Arrays:里面都是静态方法,直接用来对各种集合进行操作的公有方法. Collections:里面都是静态方法,直接用来对各种集合进行操作的公有方法. 包括: 1.asList将数组变成list集合: static <T> List<T> asList(T... a) 返回一个受指定数组支持的固定大小的列表. //例子1: import java.util.*; class ArraysTest { public static void sop(Object o