知名互联网公司校招 Java 开发岗面试知识点解析
Others:限于篇幅,面试中 Java 基础知识点还有:反射、泛型、注解等。 小结:本节主要阐述了 Java 基础知识点,这些问题主要是一面面试官在考察,难度不大,适当复习下,应该没什么问题。 (二)Java 中常见集合集合这方面的考察相当多,这部分是面试中必考的知识点。 1)说说常见的集合有哪些吧? 答:Map 接口和 Collection 接口是所有集合框架的父接口:
(2)HashMap 和 Hashtable 的区别有哪些?(必问) 答:
3)HashMap 的底层实现你知道吗? 答:在 Java8 之前,其底层实现是数组 + 链表实现,Java8 使用了数组 + 链表 + 红黑树实现。此时你可以简单的在纸上画图分析: 4)ConcurrentHashMap 和 Hashtable 的区别??(必问) 答:ConcurrentHashMap 结合了 HashMap 和 HashTable 二者的优势。HashMap 没有考虑同步,hashtable 考虑了同步的问题。但是 hashtable 在每次同步执行时都要锁住整个结构。 ConcurrentHashMap 锁的方式是稍微细粒度的。 ConcurrentHashMap 将 hash 表分为 16 个桶(默认值),诸如 get,put,remove 等常用操作只锁当前需要用到的桶。 面试官:ConcurrentHashMap 的具体实现知道吗? 答:
5)HashMap 的长度为什么是 2 的幂次方? 答:
更糟的是这种情况中,数组可以使用的位置比数组长度小了很多,这意味着进一步增加了碰撞的几率,减慢了查询的效率!这样就会造成空间的浪费。 6)List 和 Set 的区别是啥? 答:List 元素是有序的,可以重复;Set 元素是无序的,不可以重复。 7)List、Set 和 Map 的初始容量和加载因子 答: 1. List
2. Set HashSet,初始容量为 16,加载因子为 0.75; 扩容增量:原容量的 1 倍; 如 HashSet 的容量为 16,一次扩容后容量为 32 3. Map HashMap,初始容量 16,加载因子为 0.75; 扩容增量:原容量的 1 倍; 如 HashMap 的容量为 16,一次扩容后容量为 32 8)Comparable 接口和 Comparator 接口有什么区别? 答:
9)Java 集合的快速失败机制 “fail-fast” 答:它是 java 集合的一种错误检测机制,当多个线程对集合进行结构上的改变的操作时,有可能会产生 fail-fast 机制。 例如 :假设存在两个线程(线程 1、线程 2),线程 1 通过 Iterator 在遍历集合 A 中的元素,在某个时候线程 2 修改了集合 A 的结构(是结构上面的修改,而不是简单的修改集合元素的内容),那么这个时候程序就会抛出 ConcurrentModificationException 异常,从而产生 fail-fast 机制。 原因: 迭代器在遍历时直接访问集合中的内容,并且在遍历过程中使用一个 modCount 变量。集合在被遍历期间如果内容发生变化,就会改变 modCount 的值。 每当迭代器使用 hashNext()/next() 遍历下一个元素之前,都会检测 modCount 变量是否为 expectedmodCount 值,是的话就返回遍历;否则抛出异常,终止遍历。 (编辑:晋中站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |