java集合常见面试题

上一篇 <<<HashTable底层实现原理及和ConcurrentHashMap区别
下一篇 >>>MySQL发展历程与整体架构


Vector、Arraylist、CopyOnWriteArrayList区别

相同点:
1、都实现了List接口
2、底层都是用数组实现
3、数组都可以动态扩容

ArrayList和Vector主要区别

(1):Vector是线程安全的,源码中有很多的synchronized可以看出,而ArrayList不是。导致Vector效率无法和ArrayList相比;
(2):ArrayList和Vector都采用线性连续存储空间,当存储空间不足的时候,ArrayList默认增加为原来的50%,Vector默认增加为原来的一倍;
(3):Vector可以设置capacityIncrement,而ArrayList不可以,从字面理解就是capacity容量,Increment增加,容量增长的参数。

LinkedList和ArrayList相比哪个效率高

ArrayList 是线性表(数组)
get() 直接读取第几个下标,复杂度 O(1)
add(E) 添加元素,直接在后面添加,复杂度O(1)
add(index, E) 添加元素,在第几个元素后面插入,后面的元素需要向后移动,复杂度O(n)
remove()删除元素,后面的元素需要逐个移动,复杂度O(n)

LinkedList 是链表的操作
get() 获取第几个元素,依次遍历,复杂度O(n)
add(E) 添加到末尾,复杂度O(1)
add(index, E) 添加第几个元素后,需要先查找到第几个元素,直接指针指向操作,复杂度O(n)
remove()删除元素,直接指针指向操作,复杂度O(1)

对比Arraylist、LinkeList、HashMap查询时间复杂度为多少

Arraylist的底层是采用数组实现,根据下标查询时间复杂度为o(1)、根据内容查询时间复杂度o(n);
LinkeList底层采用链表实现,根据下标查询时间复杂度为o(n)、根据内容查询时间复杂度为o(n);
Jdk7HashMap底层数组+链表实现,根据key查询时间复杂度为o(1)或o(n),hashcode不冲突为o(1),冲突情况下为o(n)。

时间复杂度指的就是一个算法执行所耗费的时间
空间复杂度定义为该算法所耗费的存储空间

HashMap与HashTable之间的区别

1、HashMap实现不同步,线程不安全。 HashTable线程安全 HashMap中的key-value都是存储在Entry中的。
2、继承不同。
  Hashtable 继承 Dictionary 类,而 HashMap 继承 AbstractMap
3、Hashtable中的方法是同步的,而HashMap中的方法在缺省情况下是非同步的。在多线程并发的环境下,可以直接使用Hashtable,但是要使用HashMap的话就要自己增加同步处理了。
4、Hashtable 中, key 和 value 都不允许出现 null 值。
在 HashMap 中, null 可以作为键,这样的键只有一个;可以有一个或多个键所对应的值为 null 。
  当 get() 方法返回 null 值时,即可以表示 HashMap 中没有该键,也可以表示该键所对应的值为 null 。因此,在HashMap 中不能由 get() 方法来判断 HashMap 中是否存在某个键, 而应该用 containsKey() 方法来判断。
5、哈希值的使用不同,HashTable直接使用对象的hashCode。而HashMap重新计算hash值 。

HashMap与LinkedHashMap的区别

HashMap底层是无序、散列存放,基于单向链表实现。
LinkedHashMap是HashMap的子类,内部通过双向链表维护键值对的顺序,每个键值对既位于哈希表中,也位于双向链表中。支持插入顺序和访问顺序,通过accessOrder参数控制。【如果为true,就是访问顺序,false根据插入顺序】

插入顺序:先添加的在前面,后添加的在后面,修改操作不影响顺序。
访问顺序:对key进行get/put后,会将对应的键值对移动到链表末尾。

HashMap如何降低Hash冲突概率

// 计算hash值
hash=(key == null) ? 0 : (h = key.hashCode()) ^ (h >>> 16)
// 使用&操作
((p = tab[i = (n - 1) & hash])

HashMap为啥要用n-1?

n为表的大小,一般为2的幂次方,减1后与操作可减少hash的碰撞。

Jdk7和JDK8中的hashMap有哪些区别

JDK7的Hashmap线程不安全,且链表如果过长会导致查询效率降低,底层扩容的时候可能会存在死循环的问题。
Jdk7中的hashMap计算hashcode值非常均摊,减少hash冲突问题,因为链表查询效率非常低。
Jdk8中hashmap计算hashcode非常简单,存在hash冲突概率比jdk7要大很多,不过新增了红黑树查询解决效率低下问题。

jdk7:数组+链表,使用头插入方式(并发扩容容易死循环问题),代码写法简单
JDK8:数组+链表+红黑树,尾插入方式,代码写法高大上,红黑树转换(数组容量≥64且链表长度大于8时转为红黑树,红黑树节点个数小于6则转为链表)
时间复杂度:
key没冲突,复杂度O(1)
key产生冲突,链表存放为O(N),红黑树存放为O(LogN)
特点:
a、key为null存放数组0位置
b、单向链表实现
c、无序散列存放

HashMap 什么情况下会造成死锁,如何解决?

jdk7在多线程情况下扩容情况下会造成死锁,因为使用了头插入法
如何解决:
a、使用concurrenthashmap
b、jdk8已经解决了这个问题,因为使用了红黑树

往hashmap中插入1W条数据,get和put什么情况下效率最高?

put最高:减少扩容的机会,所以一次性把容器弄的很大,速度就会快很多
get最高:减少hash碰撞,都从数组里取出,时间复杂度为O(1),如果hash碰撞多,从链表里取,则时间复杂度是O(n)


相关文章链接:
<<<Java集合类图总览
<<<ArrayList的添加和删除操作实现原理图解
<<<ArrayList的动态扩容、ModCount及fail-fast原理
<<<LinkedList增删改查操作底层实现原理
<<<数组拷贝的几种方式及和链表结构的对比
<<<Jdk1.7HashMap源码分析
<<<Jdk1.7HashMap如何扩容及解决死循环问题
<<<JDK1.8HashMap源码分析
<<<ConcurrentHashMap在JDK1.8版本比1.7改进了什么
<<<JDK8的HashMap中红黑树左旋右旋原理图解
<<<基于LinkedHashMap手写LRU淘汰策略
<<<HashSet集合底层实现原理
<<<HashTable底层实现原理及和ConcurrentHashMap区别

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351

推荐阅读更多精彩内容