最新Java校招面试题及答案
答:java.lang、java.util、<a class=" external" href="http://link.zhihu.com/?target=http%3A//java.io" rel="nofollow noreferrer" target="_blank"><span class="invisible">http://<span class="visible">java.io、<a class=" external" href="http://link.zhihu.com/?target=http%3A//java.net" rel="nofollow noreferrer" target="_blank"><span class="invisible">http://<span class="visible">java.net、java.sql。 7)JDK,JRE 和 JVM 的联系和区别: 答:JDK 是 java 开发工具包,是 java 开发环境的核心组件,并提供编译、调试和运行一个 java 程序所需要的所有工具,可执行文件和二进制文件,是一个平台特定的软件。 JRE 是 java 运行时环境,是 JVM 的实施实现,提供了运行 java 程序的平台。JRE 包含了 JVM,但是不包含 java 编译器 / 调试器之类的开发工具。 JVM 是 java 虚拟机,当我们运行一个程序时,JVM 负责将字节码转换为特定机器代码,JVM 提供了内存管理 / 垃圾回收和安全机制等。 这种独立于硬件和操作系统,正是 java 程序可以一次编写多处执行的原因。 区别:
Others:限于篇幅,面试中 Java 基础知识点还有:反射、泛型、注解等。 小结:本节主要阐述了 Java 基础知识点,这些问题主要是一面面试官在考察,难度不大,适当复习下,应该没什么问题。 (二)Java 中常见集合集合这方面的考察相当多,这部分是面试中必考的知识点。 1)说说常见的集合有哪些吧? 答:Map 接口和 Collection 接口是所有集合框架的父接口:
(2)HashMap 和 Hashtable 的区别有哪些?(必问) 答:
3)HashMap 的底层实现你知道吗? 答:在 Java8 之前,其底层实现是数组 + 链表实现,Java8 使用了数组 + 链表 + 红黑树实现。此时你可以简单的在纸上画图分析: <img src="https://www.52php.cn/res/2019/03-16/23/3ef2329fc0cba6b90c92db6599961d16.jpg" alt=""> 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 机制。 (编辑:武汉站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |