在Java开发面试中,面试官最常问到的就是Java集合,免不了要让面试者说出之间的区别,下面博主就对其做了总结。

1、集合与数组的区别

  • 长度区别:数组是固定长度,集合长度可变;
  • 内容区别:数组可以是基本类型,也可以是引用类型;集合只能是引用类型;
  • 元素内容:数组只能存储同一种类型;集合可以存储不同类型;

2、List接口,Set接口是Collection接口的子接口

List一共有三个实现类:ArrayList,Vector,LinkedList

ArrayList 和 LinkedList,Vector (数组实现,线程同步)都是继承了AbstractList类,实现了List接口的容器类,用于存储一系列的对象引用。

List有序,可重复

ArrayList LinkedList Vector
底层结构 动态有序数组 双向循环链表 有序数组
操作速度 查询快,增删慢,效率高 查询慢,增删快,效率高 查询快,增删慢,效率低
线程是否安全 线程不安全 线程不安全 线程安全,效率低
容量不足时 当前容量*1.5+1 默认扩展一倍容量
是否可重复 排列有序,可重复 排列有序,可重复 排列有序,可重复
使用场景 查询多,插入、删除较少 查询少,插入、删除较多

3、HashSet(Hash表)和TreeSet继承了AbstractSet类,实现了Set接口,LinkedHashSet继承了HashSet类,实现了Set接口

Set无序,唯一

HashSet TreeSet LinkedHashSet
底层原理结构 Hash表(无序,唯一) 红黑树(有序,唯一) 链表和哈希表 (FIFO插入有序,唯一)
保证元素唯一性的方法 依赖两个方法:hashCode(), equals() 自然排序,比较排序(有序) 根据比较返回值是否是0(唯一) 链表保证元素有序 哈希表保证元素唯一
存取速度 排序存储 Hash表存储,并用双向链表记录插入顺序
是否可重复 排列无序,不可重复 排列有序,不可重复
内部结构 HashMap TreeMap,SortedSet LinkedHashMap

HashSet存储元素的顺序是按照哈希值来存的,也是按照哈希值取得,元素的哈希值是通过元素的hashcode方法来获取,HashSet首先判断两个元素的哈希值,如果哈希值一样,接着会比较equals方法,如果equals结果为true,HashSet就视为同一个元素,否则不是同一个元素。

4、TreeMap和HashMap继承了AbstractMap类,实现了Map接口,HashTable实现了Map接口,TreeMap实现了SortedMap接口

HashMap TreeMap HashTable
是否有序 无序 有序 无序
(K,V)是否可重复 K不可重复,V可重复 K不可重复,V可重复 K不可重复,V可重复
底层原理 哈希表 红黑树 哈希表
线程是否安全 不安全 不安全 安全
(K,V)是否可允许为空 K允许,V允许 K不允许,V不允许
方法是否同步 方法不同步 方法同步

Java中List,Set,Map区别的更多相关文章

  1. Java中的映射Map - 入门篇

    前言 大家好啊,我是汤圆,今天给大家带来的是<Java中的映射Map - 入门篇>,希望对大家有帮助,谢谢 简介 前面介绍了集合List,这里开始简单介绍下映射Map,相关类如下图所示 正 ...

  2. Java中如何遍历Map对象的4种方法

    在java中遍历Map有不少的方法.我们看一下最常用的方法及其优缺点. 既然java中的所有map都实现了Map接口,以下方法适用于任何map实现(HashMap, TreeMap, LinkedHa ...

  3. java中ArrayList 、LinkList区别

    转自:http://blog.csdn.net/wuchuanpingstone/article/details/6678653 个人建议:以下这篇文章,是从例子说明的方式,解释ArrayList.L ...

  4. 转!! Java中如何遍历Map对象的4种方法

    在Java中如何遍历Map对象 How to Iterate Over a Map in Java 在java中遍历Map有不少的方法.我们看一下最常用的方法及其优缺点. 既然java中的所有map都 ...

  5. 【转】Java中如何遍历Map对

    在Java中如何遍历Map对象 How to Iterate Over a Map in Java 在java中遍历Map有不少的方法.我们看一下最常用的方法及其优缺点. 既然java中的所有map都 ...

  6. java 中 ==和equals 的区别

      Java中equals和==的区别 java中的数据类型,可分为两类: 1.基本数据类型,也称原始数据类型.byte,short,char,int,long,float,double,boolea ...

  7. java中equals和==的区别 (转)

    java中equals和==的区别  值类型是存储在内存中的堆栈(以后简称栈),而引用类型的变量在栈中仅仅是存储引用类型变量的地址,而其本身则存储在堆中. ==操作比较的是两个变量的值是否相等,对于引 ...

  8. 【转】Java中equals和==的区别

    [转]Java中equals和==的区别 java中的数据类型,可分为两类: 1.基本数据类型,也称原始数据类型.byte,short,char,int,long,float,double,boole ...

  9. 【转】Java中如何遍历Map对象的4种方法

    原文网址:http://blog.csdn.net/tjcyjd/article/details/11111401 在Java中如何遍历Map对象 How to Iterate Over a Map ...

  10. java中a++与++a区别

    java中a++与++a区别 a++与++a的区别,如果单独使用没有任何区别,如果在运算中就有区别了,a++是先运算在赋值,而++a是先赋值在运算!! 先看a++的代码哦 class demo1 { ...

随机推荐

  1. 【线段树分治】Dash Speed

    代码的美妙 #include <bits/stdc++.h> %:pragma GCC optimize(3) using namespace std; const int maxn=7e ...

  2. spring boot:配置druid数据库连接池(开启sql防火墙/使用log4j2做异步日志/spring boot 2.3.2)

    一,druid数据库连接池的功能? 1,Druid是阿里巴巴开发的号称为监控而生的数据库连接池 它的优点包括: 可以监控数据库访问性能 SQL执行日志 SQL防火墙 2,druid的官方站: http ...

  3. .Net Core单元测试规范

    .Net Core单元测试规范 一. 前言 为了有效提升代码质量,保证DevOps的顺利进行.将全面开始采用单元测试进行覆盖,届时单元测试将完全纳入 到完整的持续构建生命周期中做为第一道质量把控的门槛 ...

  4. js读取xml,javascript读取XML

    IE下示例代码: var xmlDoc = "<root><AlleyWay><Code>1103</Code><Name>胡同2 ...

  5. 修改apt,pip,npm为国内镜像源

    apt 原文件备份 sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak 编辑源列表文件 sudo vim /etc/apt/sources. ...

  6. Codeforces Round 665 赛后解题报告(暂A-D)

    Codeforces Round 665 赛后解题报告 A. Distance and Axis 我们设 \(B\) 点 坐标为 \(x(x\leq n)\).由题意我们知道 \[\mid(n-x)- ...

  7. 请勿过度依赖Redis的过期监听!!

    作者:迪壳 https://juejin.im/post/6844904158227595271 Redis 过期监听场景 业务中有类似等待一定时间之后执行某种行为的需求 , 比如 30 分钟之后关闭 ...

  8. Afinal简介和使用方法

    Afinal简介 Afinal 是一个android的sqlite orm 和 ioc 框架.同时封装了android中的http框架,使其更加简单易用: 使用finalBitmap,无需考虑bitm ...

  9. 3. Distributional Reinforcement Learning with Quantile Regression

    C51算法理论上用Wasserstein度量衡量两个累积分布函数间的距离证明了价值分布的可行性,但在实际算法中用KL散度对离散支持的概率进行拟合,不能作用于累积分布函数,不能保证Bellman更新收敛 ...

  10. js 实现吸顶效果 || 小程序的吸顶效果

    小程序吸顶效果 <!--index.wxml--> <view class="container"> <view class='outside-img ...