HashSet与HashMap区别

HashMap实现了Map接口 
HashSet实现了Set接口

HashMap储存键值对 
HashSet仅仅存储对象

HashMap使用put()方法将元素放入map中 
HashSet使用add()方法将元素放入set中

HashMap中使用键对象来计算hashcode值 
HashSet使用成员对象来计算hashcode值

HashMap比较快,因为是使用唯一的键来获取对象

HashSet较HashMap来说比较慢

HashTable与HashMap的区别

Hashtable方法是同步的 
HashMap方法是非同步的

Hashtable基于Dictionary类 
HashMap基于AbstractMap,而AbstractMap基于Map接口的实现

Hashtable中key和value都不允许为null,遇到null,直接返回 NullPointerException 
HashMap中key和value都允许为null,遇到key为null的时候,调用putForNullKey方法进行处理,而对value没有处理

Hashtable中hash数组默认大小是11,扩充方式是old*2+1 
HashMap中hash数组的默认大小是16,而且一定是2的指数

什么是ArrayList

ArrayList可以理解为动态数组,它的容量能动态增长,该容量是指用来存储列表元素的数组的大小,随着向ArrayList中不断添加元素,其容量也自动增长 
ArrayList允许包括null在内的所有元素 
ArrayList是List接口的非同步实现 
ArrayList是有序的

定义如下:

public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable{}

ArrayList实现了List接口、底层使用数组保存所有元素,其操作基 本上是对数组的操作

ArrayList继承了AbstractList抽象类,它是一个数组队列,提供了相关的添加、删除、修改、遍历等功能

ArrayList实现了RandmoAccess接口,即提供了随机访问功能,RandmoAccess是java中用来被List实现,为List提供快速访问功能的,我们可以通过元素的序号快速获取元素对象,这就是快速随机访问

ArrayList实现了Cloneable接口,即覆盖了函数clone(),能被克隆 
ArrayList实现了java.io.Serializable接口,意味着ArrayList支持序列化

什么是LinkedList

LinkedList基于链表的List接口的非同步实现 
LinkedList允许包括null在内的所有元素 
LinkedList是有序的 
LinkedList是fail-fast的

LinkedList与ArrayList的区别

LinkedList底层是双向链表 
ArrayList底层是可变数组

LinkedList不允许随机访问,即查询效率低 
ArrayList允许随机访问,即查询效率高

LinkedList插入和删除效率快 
ArrayList插入和删除效率低

解释一下:

对于随机访问的两个方法,get和set,ArrayList优于LinkedList,因为LinkedList要移动指针 
对于新增和删除两个方法,add和remove,LinedList比较占优势,因为ArrayList要移动数据

什么是ConcurrentHashMap

ConcurrentHashMap基于双数组和链表的Map接口的同步实现 
ConcurrentHashMap中元素的key是唯一的、value值可重复 
ConcurrentHashMap不允许使用null值和null键 
ConcurrentHashMap是无序的

为什么使用ConcurrentHashMap

我们都知道HashMap是非线程安全的,当我们只有一个线程在使用HashMap的时候,自然不会有问题,但如果涉及到多个线程,并且有读有写的过程中,HashMap就会fail-fast。要解决HashMap同步的问题,我们的解决方案有

Hashtable 
Collections.synchronizedMap(hashMap) 
这两种方式基本都是对整个hash表结构加上同步锁,这样在锁表的期间,别的线程就需要等待了,无疑性能不高,所以我们引入ConcurrentHashMap,既能同步又能多线程访问

ConcurrentHashMap的数据结构

ConcurrentHashMap的数据结构为一个Segment数组,Segment的数据结构为HashEntry的数组,而HashEntry存的是我们的键值对,可以构成链表。可以简单的理解为数组里装的是HashMap

从上面的结构我们可以了解到,ConcurrentHashMap定位一个元素的过程需要进行两次Hash操作,第一次Hash定位到Segment,第二次Hash定位到元素所在的链表的头部,因此,这一种结构的带来的副作用是Hash的过程要比普通的HashMap要长,但是带来的好处是写操作的时候可以只对元素所在的Segment进行加锁即可,不会影响到其他的Segment。正是因为其内部的结构以及机制,ConcurrentHashMap在并发访问的性能上要比Hashtable和同步包装之后的HashMap的性能提高很多。在理想状态下,ConcurrentHashMap 可以支持 16 个线程执行并发写操作(如果并发级别设置为 16),及任意数量线程的读操作

HashMap、LinkedHashMap、ConcurrentHashMap、ArrayList、LinkedList的底层实现。相关推荐

  1. HashTable, HashMap, LinkedHashMap, ConcurrentHashMap

    HashTable: 不允许null的key或value, 线程安全 HashMap: 允许一个null的key, 无限的null value, 非线程安全 LinkedHashMap: HashMa ...

  2. java温故笔记(二)java的数组HashMap、ConcurrentHashMap、ArrayList、LinkedList

    为什么80%的码农都做不了架构师?>>>    HashMap 摘要 HashMap是Java程序员使用频率最高的用于映射(键值对)处理的数据类型.随着JDK(Java Develo ...

  3. ArrayList ,LinkedList,Vector,StringBuilder,StringBuffer ,String,HashMap,LinkedHashMap,TreeMap

    ArrayList ,LinkedList,Vector 区别和联系 从上面的类层次结构图中,我们可以发现他们都实现了List接口,它们使用起来非常相似.区别主要在于它们各自的实现,不同的实现导致了不 ...

  4. java基础巩固-宇宙第一AiYWM:为了维持生计,多高(多线程与高并发)_Part9~整起(单双列集合们、ArrayList 的扩容机制、HashMap、ConcurrentHashMap )

    再进入正文之前,先看看集合相关操作的时间复杂度: 本故事源自于~ 开唠: PART0: 为什么突然蹦出集合这个玩意,就是因为咱们基础那里学的"数组"不够用~: 数组一般用来保存一组 ...

  5. Java中的Map集合及其子类HashMap,LinkedHashMap,TreeMap,ConcurrentHashMap

    一 .Map public interface Map<K,V> 将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值.此接口哦取代了Dictionary类,后者完全是 ...

  6. Java Collection系列之HashMap、ConcurrentHashMap、LinkedHashMap的使用及源码分析

    文章目录 HashMap HashMap的存储结构 初始化 put & get put元素 get元素 扩容 遍历Map jdk1.8中的优化 ConcurrentHashMap jdk1.7 ...

  7. Vector ArrayList Hashtable HashMap ArrayList LinkedList

    1. Vector & ArrayList 1)  Vector的方法都是同步的(Synchronized),是线程安全的(thread-safe),而ArrayList的方法不是,由于线程的 ...

  8. 集合之比较接口器+Map家族的HashMap+LinkedHashMap+Hashtable+ConcurrentHashMap

    集合之比较接口器+Map家族的HashMap+LinkedHashMap+Hashtable+ConcurrentHashMap 一.比较器接口 1.内置比较器 – Comparable import ...

  9. java的知识点23——泛型Generics、Collection接口、List特点和常用方法、 ArrayList特点和底层实现

    泛型Generics 一般通过"容器"来容纳和管理数据.程序中的"容器"就是用来容纳和管理数据. 数组就是一种容器,可以在其中放置对象或基本类型数据. 数组的优 ...

  10. hashmap与concurrenthashmap源码解析

    hashmap源码解析转载:http://www.cnblogs.com/ITtangtang/p/3948406.html 一.HashMap概述 HashMap基于哈希表的 Map 接口的实现.此 ...

最新文章

  1. Linux 安装 Elasticsearch-rtf
  2. geotools学习(一)IntelliJ IDEA搭建快速入门示例.pdf
  3. java的死锁是什么意思_Java面试题:什么是死锁?如何手写一个死锁(Dead Lock)...
  4. python列表按照批次分配数据(亲测)
  5. 牛客 2021年度训练联盟热身训练赛第二场 B题
  6. 无法启动QPCore Service
  7. VS2008中英文转换
  8. 云南昭通暴雨强度公式_昆明市暴雨强度公式推算与对比
  9. CentOS 7 配置免密码证书登录
  10. 大数据思维的核心是什么?
  11. ASO选词估量该怎么做?aso怎么选词
  12. 爬取Google网站的图片
  13. 华为鸿蒙 OS 尝鲜,跑了个 “hello world”!跑通后,我特么开始怀疑人生...
  14. 【寻找最佳小程序】02期:腾讯旅游首款小工具“旅行小账本”——创意及研发过程大起底...
  15. 养生年龄的早龄化一一朱乐睿教授
  16. 脸上8部位长痘原因与器官关系
  17. 如何增加微信朋友圈分享链接的小图片
  18. 利用Jquery自动生成条形码
  19. 微信小程序模拟车位选择功能(简陋版本)
  20. 企业知识管理包括哪些内容?

热门文章

  1. python中的顿号与加号
  2. 中山纪念中学集训日志
  3. 傅老师的unity黑魂复刻学习日记(六)
  4. android图片_画画板
  5. vue中slot,slot-scope,v-slot的用法和区别
  6. 什么蓝牙耳机好?业内权威蓝牙耳机排名TOP5
  7. abaqus dat文件 matlab_工程师联盟科普系列|ABAQUS中的各种文件类型详解-dat文件如何打开...
  8. 用java实现HTTPS工作原理的例子
  9. LaTeX安装教程(TeX Live+TeXstudio)
  10. 【河南省第二届技能大赛-物联网技术】C模块Python开发讲解