美文网首页
java集合总结

java集合总结

作者: 简书汪 | 来源:发表于2017-11-30 16:19 被阅读0次

Java集合工具包位于Java.util包下,包含了很多常用的数据结构,如数组、链表、栈、队列、集合、哈希表等。学习Java集合框架下大致可以分为如下五个部分:List列表、Set集合、Map映射、迭代器(Iterator、Enumeration)、工具类(Arrays、Collections)。
Java集合类的整体框架如下:


ArrayList

  • 结构:基于数组实现,是一个动态数组,其容量能自动增长
  • 特点:
    1. ArrayList基于数组实现,可以通过下标索引直接查找到指定位置的元素,因此查找效率高,但每次插入或删除元素,就要大量地移动元素,插入删除元素的效率低。
    2. ArrayList中允许元素为null。
    3. ArrayList的实现中大量地调用了Arrays.copyof()和System.arraycopy()方法。
    4. 是非线程安全的,只在单线程下适合使用。

LinkedList

  • 结构:基于双向循环链表实现的


  • 特点
    1. LinkedList是基于链表实现的,因此不存在容量不足的问题,所以这里没有扩容的方法。
    2. LinkedList中允许元素为null。
    3. inkedList是基于链表实现的,因此插入删除效率高,查找效率低(虽然有一个加速动作)。
    4. 是非线程安全的,只在单线程下适合使用。

HashMap

  • 结构: 基于哈希表实现的,每一个元素都是一个key-value对,其内部通过单链表解决冲突问题,容量不足(超过了阈值)时,同样会自动增长。


  • 特点:
    1. 初始容量和加载因子是影响HashMap性能的重要参数,当哈希表中的条目数超出了加载因子与当前容量的乘积时,则要对该哈希表进行 resize 操作(即扩容)。
    2. HashMap中key和value都允许为null。
    3. 无论我们指定的容量为多少,构造方法都会将实际容量设为不小于指定容量的2的次方的一个数,且最大值不能超过2的30次方
    4. 计算key的hash值用"&"运算
    5. 非线程安全的,只是用于单线程环境下

HashTable

  • 结构:同样是基于哈希表实现的,同样每个元素都是key-value对,其内部也是通过单链表解决冲突问题,容量不足(超过了阈值)时,同样会自动增长。
  • 特点:
    1. 是线程安全的,能用于多线程环境中。
    2. Hashtable中key和value都不允许为null
    3. Hashtable不要求底层数组的容量一定要为2的整数次幂
    4. Hashtable在求hash值对应的位置索引时,用取模运算
    5. 与HashMap存储结构和解决冲突的方法都是相同的。

HashSet

  • 结构:基于HashMap实现
  • 特点:
    1. 它不允许出现重复元素
    2. 不保证集合中元素的顺序
    3. 允许包含值为null的元素,但最多只能有一个null元素。
    4. 非线程安全的,只是用于单线程环境下

TreeMap

  • 结构:是一个有序的key-value集合,它是通过红黑树实现的

  • 特点:

    1. 存储的数据是有序的
    2. 允许包含键为null
    3. 键值不允许重复
    4. 非线程安全的,只是用于单线程环境下

TreeSet

  • 结构:基于TreeMap实现
  • 特点:与TreeMap类似,与之不同的是提供有序的Set集合

相关文章

  • Java集合框架总结篇

    Java集合框架总结篇

  • java集合框架学习总结

    title: java集合框架学习总结 tags:集合框架 categories:总结 date: 2017-03...

  • Java集合总结

    Java集合总结 概述 Java集合类主要由两个接口派生而出: Collection Map 这两个是Java集合...

  • java中遍历list、set、map集合的常用方法

    前言:java的集合框架细节阐述我们这里就不赘述了,可参考Java - 集合框架完全解析,这里只总结java集合的...

  • 常用数据结构

    Java 集合系列目录(Category) 下面是最近总结的Java集合(JDK1.6.0_45)相关文章的目录。...

  • Java基础面试总结

    【面试汇总】Java面试题-1Java面试题-2 【集合】Java集合及concurrent并发包总结(转)Jav...

  • Java集合框架使用总结

    Java集合框架使用总结 前言: 本文是对Java集合框架做了一个概括性的解说,目的是对Java集合框架体系有个总...

  • 面试总结-Java高级篇

    Java面试总结 1.你用过哪些集合类? 大公司最喜欢问的Java集合类面试题 40个Java集合面试问题和答案 ...

  • Java集合总结

    Java集合类主要有2大分支,Collection及Map。Collection体系如下: Map体系如下: **...

  • java集合总结

    本文原链接点我查看 前言 在PHP中,集合是很简单的,就一个Array,既可以做数组,又可以做map,对比JAVA...

网友评论

      本文标题:java集合总结

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