为了保证制作简历的安全性和流畅性,建议您使用Chrome浏览器进行访问
猫汤 学校
APP 内打开
3
20
156

Java 面试都只是背答案吗?

我敢百分百这么说!如果不背 Java 面试题的答案,肯定面试会挂!Java 面试题就像我们高考时的文言文,包括古诗词,不背是不可能答出来的!当然了,除了背,还得理解,否则意义不大,对面试过后的工作帮助也不大!

我在五年之前参加过多场面试,应聘的岗位均为 Java 工程师,在不断地面试过程中,分类总结了面试中的一些知识点,这里受篇幅限制我先讲一下java的知识点和java的常见集合


面试是大家从学校走向社会的第一步。互联网公司的校园招聘,从形式上说,一般分为 2~3 轮技术面试 +1 轮 HR 面试,不过某些公司没有 HR 面试。在技术面试中,面试官一般会先就你所应聘的岗位进行相关知识的考察,也叫基础知识和业务逻辑面试,只要回答的不是特别差,面试官通常会说:“咱们写个代码吧”,这个时候就开始了算法面试。也就是说,一轮技术面试 = 基础知识和业务逻辑面试 + 算法面试。算法题就好像科举考试时代背的八股文,是知识改变命运的代表作。你不刷,不管是校招还是社招,就很过算法题这一关。


这里我们主要从技术面试聊起,技术面试包括:业务逻辑和基础知识面试。首先是业务逻辑面试,也就是讲项目,面试官会根据简历上写的若干个项目的其中之一拿出来和你聊聊。在期间,会针对你所做的东西进行深度挖掘,包括:为什么要这么做?优缺点分析,假如重新让你再做一次,打算怎么做?……,这个环节主要考察我们对自己做过的项目(实习项目或者校内项目)是否有一个清晰的认识。关于业务逻辑面试的准备,建议在平时多多思考总结,对项目的数据来源、整体运行框架都应该熟悉掌握,比如,在某公司实习过程中,就可以进行总结,而不必等到快离职的时候再慌慌张张的去总结该项目。接下来是基础知识面试。Java 开发属于后台开发的方向,有人说后台开发很坑,因为需要学习的东西太多了,没错,这个岗位就是需要学习好多东西,包括本语言(Java / C++ / PHP)基础、数据库、网络协议、Linux 系统、计算机原理甚至前端相关知识都可以考察,而且,并不超纲。有时候,你报的是后台开发岗,并且熟悉的是 Java 语言,但是面试官却是 C++ 开发方向的,就是这么无奈~


(一)Java 基础知识点

(1)面向对象的特性有哪些?答:封装、继承和多态。

(2)Java 中覆盖和重载是什么意思?解析:覆盖和重载是比较重要的基础知识点,并且容易混淆,面试中也比较常见。答:覆盖(Override)是指子类对父类方法的一种重写,只能比父类抛出更少的异常,访问权限不能比父类的小。被覆盖的方法不能是 private 的,否则只是在子类中重新定义了一个方法。重载(Overload)表示同一个类中可以有多个名称相同的方法,但这些方法的参数列表各不相同。

面试官:那么构成重载的条件有哪些?答:参数类型不同、参数个数不同、参数顺序不同。

面试官:函数的返回值不同可以构成重载吗?为什么?答:不可以,因为 Java 中调用函数并不需要强制赋值。

(3)抽象类和接口的区别有哪些?答:抽象类中可以没有抽象方法,接口中的方法必须是抽象方法;抽象类中可以有普通的成员变量,接口中的变量必须是 static final 类型的,必须被初始化,接口中只有常量,没有变量;抽象类只能单继承,接口可以继承多个父接口;Java 8 中接口中会有 default 方法,即方法可以被实现。


接问:抽象类和接口如何选择?答:如果要创建不带任何方法定义和成员变量的基类,那么就应该选择接口而不是抽象类;如果知道某个类应该是基类,那么第一个选择的应该是让它成为一个接口,只有在必须要有方法定义和成员变量的时候,才应该选择抽象类,因为抽象类中允许存在一个或多个被具体实现的方法,只要方法没有被全部实现该类就仍是抽象类。

(4)Java 和 C++ 的区别是什么?解析:虽然我们不太懂 C++,但也会这么问,尤其是在三面的(总监级别)面试中。答:都是面向对象的语言,都支持封装、继承和多态指针,Java 不提供指针来直接访问内存,程序更加安全继承,Java 的类是单继承的,C++ 支持多重继承;Java 通过一个类实现多个接口来实现 C++ 中的多重继承;Java 中类不可以多继承,但是接口可以多继承内存:Java 有自动内存管理机制,不需要程序员手动释放无用内存

(5)Java 中的值传递和引用传递解析:这类题目,面试官会手写一个例子,要求说出函数执行结果,详细举例请查阅我的博客:Java 值传递和引用传递基础分析。答:值传递是指对象被值传递,意味着传递了对象的一个副本,即使副本被改变,也不会影响源对象。引用传递是指对象被引用传递,意味着传递的并不是实际的对象,而是对象的引用。因此,外部对引用对象的改变会反映到所有的对象上。

(6)JDK 中常用的包有哪些?答:java.lang、java.util、http://java.io、http://java.net、java.sql。

(7)JDK、JRE 和 JVM 的联系和区别各是什么?答:JDK 是 Java 开发工具包,是 Java 开发环境的核心组件,并提供编译、调试和运行一个 Java 程序所需要的所有工具,可执行文件和二进制文件,是一个平台特定的软件。JRE 是 Java 运行时环境,是 JVM 的实施实现,提供了运行 Java 程序的平台,JRE 包含了 JVM,但是不包含 Java 编译器/调试器之类的开发工具。JVM 是 Java 虚拟机,当我们运行一个程序时,JVM 负责将字节码转换为特定机器代码,JVM 提供了内存管理/垃圾回收和安全机制等。这种独立于硬件和操作系统,正是 Java 程序可以一次编写多处执行的原因。区别:JDK 用于开发,JRE 用于运行 Java 程序JDK 和 JRE 中都包含 JVMJVM 是 Java 编程语言的核心并且具有平台独立性


(二)Java 中常见集合

集合这方面的考察相当多,这部分是面试中必考的知识点。

(1)说说常见的集合有哪些吧?答:Map 接口和 Collection 接口是所有集合框架的父接口。Collection 接口的子接口包括:Set 接口和 List 接口。Map 接口的实现类主要有:HashMap、TreeMap、Hashtable、ConcurrentHashMap 及 Properties 等。Set 接口的实现类主要有:HashSet、TreeSet 及 LinkedHashSet 等。List 接口的实现类主要有:ArrayList、LinkedList、Stack 及 Vector 等。

(2)HashMap 和 HashTable 的区别有哪些?(必问)答:HashMap 没有考虑同步,是线程不安全的;HashTable 使用了 synchronized 关键字,是线程安全的;前者允许 null 作为 Key;后者不允许 null 作为 Key。

(3)HashMap 的底层实现你知道吗?答:在 Java 8 之前,其底层实现是数组 + 链表实现,Java 8 使用了数组 + 链表 + 红黑树实现

(4)ConcurrentHashMap 和 HashTable 的区别? (必问)答:ConcurrentHashMap 结合了 HashMap 和 HashTable 二者的优势。HashMap 没有考虑同步,HashTable 考虑了同步的问题,但是 HashTable 在每次同步执行时都要锁住整个结构。ConcurrentHashMap 锁的方式是稍微细粒度的,同时将 Hash 表分为 16 个桶(默认值),诸如 get、put、remove 等常用操作只锁当前需要用到的桶。面试官:ConcurrentHashMap 的具体实现知道吗?答:该类包含两个静态内部类 HashEntry 和 Segment;前者用来封装映射表的键值对,后者用来充当锁的角色;Segment 是一种可重入的锁 ReentrantLock,每个 Segment 守护一个 HashEntry 数组里得元素,当对 HashEntry 数组的数据进行修改时,必须首先获得对应的 Segment 锁。

(5)HashMap 的长度为什么是 2 的幂次方?答:通过将 Key 的 hash 值与 length−1 进行 & 运算,实现了当前 Key 的定位,2 的幂次方可以减少冲突(碰撞)的次数,提高 HashMap 查询效率。如果 length 为 2 的次幂,则 length−1 转化为二进制必定是 11111…的形式,在于 h 的二进制与操作效率会非常的快,而且空间不浪费;如果 length 不是 2 的次幂,比如 length 为 15,则 length−1 为 14,对应的二进制为 1110,在于 h 与操作,最后一位都为 0,而 0001、0011、0101、1001、1011、0111、1101 这几个位置永远都不能存放元素了,空间浪费相当大,更糟的是这种情况中,数组可以使用的位置比数组长度小了很多,这意味着进一步增加了碰撞的几率,减慢了查询的效率!这样就会造成空间的浪费。

(6)List 和 Set 的区别是什么?答:List 元素是有序的,可以重复;Set 元素是无序的,不可以重复。

(7)List、Set 和 Map 的初始容量和加载因子是什么答:a. ListArrayList 的初始容量是 10;加载因子为 0.5;扩容增量:原容量的 0.5 倍 + 1;一次扩容后长度为 16。Vector 初始容量为 10,加载因子是 1。扩容增量是原容量的 1 倍,如 Vector 的容量为 10,一次扩容后是容量为 20。b. SetHashSet 初始容量为 16,加载因子为 0.75;扩容增量是原容量的 1 倍,如 HashSet 的容量为 16,一次扩容后容量为 32。c. MapHashMap 初始容量 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 值,是的话就返回遍历;否则抛出异常,终止遍历。解决办法:在遍历过程中,所有涉及到改变 modCount 值的地方全部加上 synchronized;使用 CopyOnWriteArrayList 来替换 ArrayList。

发布时间:2021年06月09日
用户头像
我来说两句…
共 20 条评论
柠檬脾气 四川大学·2022届
实际面试:说一说你怎么理解的ssm,spring bean的生命周期?拦截器和过滤器区别?springmvc拦截器怎么实现的……面个初级,就面个初级。不问基础直接框架干上
2021年06月10日 回复
小活泼
就硬卷呗
2021年06月10日 回复
徐she'll 高级通信技术工程师
这么说吧,程序员面试,不论语言,面试之前不背题基本上都挺难的,当个然后,真实的大佬另谈。毕竟面试造航母,上班拧螺丝并不是口头说说而已
2021年06月10日 回复
纠结的空格 首都经济贸易大学·2022届
卷,劝退
2021年06月10日 回复
猫汤 纠结的空格: 确实卷啊
2021年06月10日 回复
麦子仲肥
传统的面试造火箭,入职拧螺丝
2021年06月10日 回复
猫汤 麦子仲肥:
2021年06月10日 回复
金子涵
低端岗位或者小公司需要看面试题,高端岗位或者大公司需要自己准备
2021年06月10日 回复
若水 上海对外经贸大学·2022届
我全背过了 能过面试吗
2021年06月10日 回复
空气突然安静
有用了,辛苦作者
2021年06月10日 回复
苏大泽ㄣ 东北林业大学·2022届
数据库调优 哎
2021年06月10日 回复
对酒当歌 中级C#工程师
Java里面还有很多历史遗留问题,我面试问了很多人,不看书研究过,基本上没人能答上来。
2021年06月10日 回复
猫汤 对酒当歌: 抓到大佬了。
2021年06月10日 回复
是梦境吗
へ(゜∇、°)へ
2021年06月11日 回复
ㄣ斑驳的流年_☆ぷ 吉林大学珠海学院·2022届
赞赞
2021年06月10日 回复
这题我不会啊!
小型公司,一般就一轮了。
2021年06月10日 回复
夕阳狠_ 南京大学·2022届
棒!
2021年06月10日 回复
名濑美月
比较好的互联网公司才会有几轮的技术面。中小型公司1-2面封顶了
2021年06月10日 回复
贪恋 上海对外经贸大学·2022届
期待下回解析
2021年06月10日 回复
陈朝气 哥伦比亚大学·2022届
666666
2021年06月10日 回复