2 Java中常见集合
1)说说常见的集合有哪些吧?
答:集合有两个基本接口:Collection 和 Map。
Collection 接口的子接口有:List 接口、Set 接口和 Queue 接口;
List 接口的实现类主要有:ArrayList、LinkedList、Stack 和 Vector;
Set 接口的实现类主要有:HashSet、TreeSet、LinkedHashSet;
Queue接口的实现类主要有:PriorityQueue;
Map 接口的实现类主要有:HashMap、TreeMap、Hashtable、ConcurrentHashMap 和 Properties。
2)HashMap 和 Hashtable 的区别有哪些?(必问)
答:1. HashMap 没有考虑同步,是线程不安全的;Hashtable 使用了 synchronized 关键字,是线程安全的;
2. 前者允许空值作为 Key 和 Value;后者不允许空值作为 Key 和 Value。
3)HashMap 的底层实现你知道吗?
答:在 Java8 之前,其底层实现是数组 + 链表实现,Java8 使用了数组 + 链表 + 红黑树实现。此时你可以简单的在纸上画图分析:
4)Hashtable 和 ConcurrentHashMap 的区别? (必问)
答:Hashtable 考虑了同步的问题,但是Hashtable 在每次同步执行时都要锁住整个结构。
ConcurrentHashMap 结合了 HashMap 和 HashTable 二者的优势。ConcurrentHashMap 锁的方式是稍微细粒度的。
ConcurrentHashMap 将哈希表分为 16 个桶(默认值),诸如 get,put,remove 等常用操作只锁当前需要用到的桶。
问:ConcurrentHashMap 的具体实现知道吗?
答:1. 该类包含两个静态内部类 HashEntry 和 Segment;前者用来封装映射表的键值对,后者用来充当锁的角色;
2. Segment 是一种可重入的锁 ReentrantLock,每个 Segment 守护一个 HashEntry 数组里的元素,当对 HashEntry 数组的数据进行修改时,必须首先获得对应的 Segment 锁。
5)HashMap 的长度为什么是 2 的幂次方?
答:1. 通过将 Key 的 hash 值与 length-1 进行 & 运算,实现当前 Key 的定位,2 的幂次方可以减少冲突(碰撞)的次数,提高 HashMap 查询效率;
2. 如果 length 是 2 的幂,那么 length-1 转化为二进制必定是 11111……的形式,“与”运算效率快,空间不浪费;
3. 如果 length 不是 2 的幂,如 length 为 15,那么 length-1 为 14,对应的二进制为 1110。“与”运算,最后一位都为 0。
空间浪费大:0001,0011,0101,0111,1001,1011,1101 这几个位置永远都不能存放元素。
查询效率慢:数组可用位置小于数组长度,增加碰撞几率。
6)List 和 Set 的区别是啥?
答:List 元素是有序的、可以重复;Set 元素是无序的、不可以重复。
7)List、Set 和 Map 的初始容量和加载因子
答:1. List
- ArrayList 初始容量为 10;加载因子为 0.5; 扩容增量:0.5倍原容量 + 1;一次扩容后容量为 16。
- Vector 初始容量为 10,加载因子为 1;扩容增量:1 倍原容量;一次扩容后容量为 20。
2. Set
HashSet 初始容量为 16,加载因子为 0.75; 扩容增量:1 倍原容量;一次扩容后容量为 32。
3. Map
HashMap 初始容量为 16,加载因子为 0.75; 扩容增量:1 倍原容量;一次扩容后容量为 32。
8)Comparable 接口和 Comparator 接口有什么区别?
答:1. 前者简单,但是如果需要重新定义比较类型时,那么需要修改源代码。
2. 后者不需要修改源代码,自定义一个比较器,实现自定义的比较方法。
9)Java 集合的快速失败机制 “fail-fast”
答:在用迭代器遍历一个集合对象时,如果遍历过程中对集合对象的内容进行了修改(增加、删除、修改),那么会抛出 ConcurrentModificationException。
原因,迭代器在遍历时直接访问集合中的内容,并且在遍历过程中使用一个 modCount 变量。集合在被遍历期间如果内容发生变化,就会改变 modCount 的值。每当迭代器使用 hashNext()/next() 遍历下一个元素之前,都会检测 modCount 变量是否为 expectedmodCount 值,是的话就返回遍历;否则抛出异常,终止遍历。
解决办法
在遍历过程中,所有涉及到改变 modCount 值的地方全部加上 synchronized;
使用 CopyOnWriteArrayList 来替换 ArrayList。
2 Java中常见集合的更多相关文章
- java中的集合操作类(未完待续)
申明: 实习生的肤浅理解,如发现有错误之处.还望大牛们多多指点 废话 事实上我写java的后台操作,我每次都会遇到一条语句:List<XXXXX> list = new ArrayList ...
- Java基础-JAVA中常见的数据结构介绍
Java基础-JAVA中常见的数据结构介绍 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是数据结构 答:数据结构是指数据存储的组织方式.大致上分为线性表.栈(Stack) ...
- Java中的集合和常用类
Java中的常用类: ▪ Object类 ▪ Math类 ▪ String类和StringBuffer类(字符串) ▪ 8种基本类型所对应的包装类 ▪ java.util包中的类——Date类 Obj ...
- 万字长文深入理解java中的集合-附PDF下载
目录 1. 前言 2. List 2.1 fail-safe fail-fast知多少 2.1.1 Fail-fast Iterator 2.1.2 Fail-fast 的原理 2.1.3 Fail- ...
- Java 中的集合接口——List、Set、Map
Java 中的集合接口——List.Set.Map 什么叫集合:集合就是Java API所提供的一系列类的实例,可以用于动态存放多个对象.这跟我们学过的数组差不多,那为什么我们还要学集合,我们看看数组 ...
- 实现java 中 list集合中有几十万条数据,每100条为一组取出
解决"java 中 list集合中有几十万条数据,每100条为一组取出来如何实现,求代码!!!"的问题. 具体解决方案如下: /** * 实现java 中 list集合中有几十万条 ...
- java中对集合对象list的几种循环访问
java中对集合对象list的几种循环访问的总结如下 1 经典的for循环 public static void main(String[] args) { List<String> li ...
- 菜鸟日记之 java中的集合框架
java中的集合框架图 如图所示:java中的集合分为两种Collection和Map两种接口 可分为Collection是单列集合和Map的双列集合 Collection单列集合:继承了Iterat ...
- C#与java中的集合区别
集合一般的操作 插入: add 删除: remove 查找: contains,remove java中的集合 注意哪些是接口,哪些是实现类 使用集合的时候 1. ...
随机推荐
- Linux服务器安装配置JDK
一.准备工作: 1.登录服务器,切换到root用户(su - root,然后输入密码,按enter),进入根目录:cd / 2.进入要安装jdk的目录,自己可以创建一个java目录,执行命令如下: c ...
- 使用xpath提取页面所有a标签的href属性值
# -*- coding: utf-8 -*- #1.选取节点 #获取所有的div元素 //div #/代表获取根节点的直接子元素 #获取所有带有id属性的div //div[@id] #2.谓词(索 ...
- 2017 阿里巴巴 C++后台开发一面 3.14
下午4点接到一个杭州打过来的电话,阿里巴巴一面.持续时间半个小时. 面试官是阿里云KVStore组. 1.自我介绍,说一下项目 说了下之前在公司做的手绘几何图形规整输出的项目,提了下当时遇到的问题,以 ...
- C# WCF发布服务的元数据的方式
发布服务元数据的方式有两种:一是基于HTTP-GET协议提供元数据,它是一种绝大多数平台都能支持的简单text-based协议:另一种是元数据交换终结点. 1.基于HTTP-GET协议 <?xm ...
- element-ui 弹出添加拖拽功能
1.新建dialog.js文件2.在main.js 中引入dialog.js import ‘./utils/dialog.js’3. 使用:<el-dialog v-dialogDrag&g ...
- 24. ClustrixDB 持久性配置文件
这些持久性选项不适用于内存中的表.有关更多信息,请参见内存表. ClustrixDB提供了一个选项,通过指定如何提交事务并使其持久,从而提高性能.当提交成功通知应用程序时,用户可以在提交过程中指定提交 ...
- 关系型数据库(四),引擎MyISAM和InnoDB
目录 1.MyISAM和InnoDB关于锁方面的区别是什么 2.MYSQL的两个常用存储引擎 3.MyISAM应用场景 4.InnoDB适合场景 四.引擎MyISAM和InnoDB 1.MyISAM和 ...
- C语言 - strcat和strncat的编程实现及总结
一.函数strcat与stcncat的函数实现 1.strcat函数的实现 要求: 原型:char * strcat(char *dest, const char *src); 头文件:#inc ...
- POJ3233 [C - Matrix Power Series] 矩阵乘法
解题思路 题目里要求\(\sum_{i=1}^kA^i\),我们不妨再加上一个单位矩阵,求\(\sum_{i=0}^kA^i\).然后我们发现这个式子可以写成这样的形式:\(A(A(A...)+E)+ ...
- CodeForces 788B--Weird journey
Time Limit:2000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Description Little ...