赞
踩
我在五年之前参加过多场面试,应聘的岗位均为 Java 工程师,在不断地面试过程中,分类总结了面试中的一些知识点,主要包括以下几部分:
面试是大家从学校走向社会的第一步。互联网公司的校园招聘,从形式上说,一般分为 2~3 轮技术面试 +1 轮 HR 面试,不过某些公司没有 HR 面试。在技术面试中,面试官一般会先就你所应聘的岗位进行相关知识的考察,也叫基础知识和业务逻辑面试,只要回答的不是特别差,面试官通常会说:“咱们写个代码吧”,这个时候就开始了算法面试。也就是说,一轮技术面试 = 基础知识和业务逻辑面试 + 算法面试。
这里我们主要从技术面试聊起,技术面试包括:业务逻辑和基础知识面试。 首先是业务逻辑面试,也就是讲项目,面试官会根据简历上写的若干个项目的其中之一拿出来和你聊聊。在期间,会针对你所做的东西进行深度挖掘,包括:为什么要这么做?优缺点分析,假如重新让你再做一次,打算怎么做?……,这个环节主要考察我们对自己做过的项目(实习项目或者校内项目)是否有一个清晰的认识。关于业务逻辑面试的准备,建议在平时多多思考总结,对项目的数据来源、整体运行框架都应该熟悉掌握,比如,在某公司实习过程中,就可以进行总结,而不必等到快离职的时候再慌慌张张的去总结该项目。 接下来是基础知识面试。Java 开发属于后台开发的方向,有人说后台开发很坑,因为需要学习的东西太多了,没错,这个岗位就是需要学习好多东西,包括本语言(Java / C++ / PHP)基础、数据库、网络协议、Linux 系统、计算机原理甚至前端相关知识都可以考察,而且,并不超纲。有时候,你报的是后台开发岗,并且熟悉的是 Java 语言,但是面试官却是 C++ 开发方向的,就是这么无奈~ 好了,闲话少说,让我们开始分类讲解常见面试知识点吧。
作者:沉默王二 链接:
https://www.zhihu.com/question/452184164/answer/1830356746 来源:知乎 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。 (一)Java 基础知识点 (1)面向对象的特性有哪些? 答:封装、继承和多态。 (2)Java 中覆盖和重载是什么意思? 解析:覆盖和重载是比较重要的基础知识点,并且容易混淆,面试中也比较常见。 答:覆盖(Override)是指子类对父类方法的一种重写,只能比父类抛出更少的异常,访问权限不能比父类的小。被覆盖的方法不能是 private 的,否则只是在子类中重新定义了一个方法。 重载(Overload)表示同一个类中可以有多个名称相同的方法,但这些方法的参数列表各不相同。 面试官:那么构成重载的条件有哪些? 答:参数类型不同、参数个数不同、参数顺序不同。 面试官:函数的返回值不同可以构成重载吗?为什么? 答:不可以,因为 Java 中调用函数并不需要强制赋值。举例如下: void f(){} int f(){ return 1;} 只要编译器可以根据语境明确判断出语义,比如在 int x = f(); 中,那么的确可以据此区分重载方法。不过,有时你并不关心方法的返回值,而想要的是方法调用的其他效果(这常被称为“为了副作用而调用”),这时可能会调用方法而忽略其返回值,比如像下面的调用: fun(); 此时 Java 如何才能判断调用的是哪一个 f() 呢?其他人如何理解这种代码呢?因此,根据方法返回值来区分重载方法是行不通的。 (3)抽象类和接口的区别有哪些? 答:
接问:抽象类和接口如何选择? 答:
(4)Java 和 C++ 的区别是什么? 解析:虽然我们不太懂 C++,但也会这么问,尤其是在三面的(总监级别)面试中。 答:
(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 程序可以一次编写多处执行的原因。 区别:
Others:限于篇幅的关系,面试中 Java 基础知识点还有反射、泛型、注解等,具体可详见我的博客:
(二)Java 中常见集合 集合这方面的考察相当多,这部分是面试中必考的知识点。 (1)说说常见的集合有哪些吧? 答:Map 接口和 Collection 接口是所有集合框架的父接口。
(2)HashMap 和 HashTable 的区别有哪些?(必问) 答:
(3)HashMap 的底层实现你知道吗? 答:在 Java 8 之前,其底层实现是数组 + 链表实现,Java 8 使用了数组 + 链表 + 红黑树实现(此时可以简单的在纸上画图分析):
(4)ConcurrentHashMap 和 HashTable 的区别? (必问) 答:ConcurrentHashMap 结合了 HashMap 和 HashTable 二者的优势。HashMap 没有考虑同步,HashTable 考虑了同步的问题,但是 HashTable 在每次同步执行时都要锁住整个结构。ConcurrentHashMap 锁的方式是稍微细粒度的,同时将 Hash 表分为 16 个桶(默认值),诸如 get、put、remove 等常用操作只锁当前需要用到的桶。 面试官:ConcurrentHashMap 的具体实现知道吗? 答:
(5)HashMap 的长度为什么是 2 的幂次方? 答:
(6)List 和 Set 的区别是什么? 答:List 元素是有序的,可以重复;Set 元素是无序的,不可以重复。 (7)List、Set 和 Map 的初始容量和加载因子是什么 答: a. List
b. Set HashSet 初始容量为 16,加载因子为 0.75;扩容增量是原容量的 1 倍,如 HashSet 的容量为 16,一次扩容后容量为 32。 c. 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 值,是的话就返回遍历;否则抛出异常,终止遍历。 解决办法:
小结:本节讲解了在 Java 中关于集合的考察,是 Java 岗位面试中必考的知识点,除了应该掌握以上的问题,包括各个集合的底层实现也建议大家阅读,以便加深理解。 (三)高并发编程——JUC 包 在 Java 5.0 提供了 java.util.concurrent(JUC)包,在此包中增加了在并发编程中很常用的实用工具类,用于定义类似于线程的自定义子系统,包括线程池、异步 IO 和轻量级任务框架。 (1)多线程和单线程的区别和联系 答:
结论:即采用多线程不会提高程序的执行速度,反而会降低速度,但是对于用户来说,可以减少用户的响应时间。 (2)如何指定多个线程的执行顺序? 解析:面试官会举例子,如何让 10 个线程按照顺序打印 0123456789?(写代码实现) 答:
(3)线程和进程的区别是什么(必考) 答:
(4)多线程产生死锁的 4 个必要条件? 答:
接问:如何避免死锁?(经常问) 答:指定获取锁的顺序,举例如下:
(5)sleep( ) 和 wait(n)、wait( ) 的区别是什么? 答:
(6)synchronized 关键字是什么? 答:底层实现:
含义:(monitor 机制) Synchronized 是在加锁,加对象锁。对象锁是一种重量锁(Monitor),Synchronized 的锁机制会根据线程竞争情况在运行时会有偏向锁(单一线程)、轻量锁(多个线程访问 Synchronized 区域)、对象锁(重量锁,多个线程存在竞争的情况)、自旋锁等,该关键字是一个几种锁的封装。 (7)volatile 关键字 答:该关键字可以保证可见性不保证原子性。 功能:
解析:关于指令重排序的问题,可以查阅 DCL 双检锁失效相关资料。 (8)ThreadLocal(线程局部变量)关键字 答:当使用 ThreadLocal 维护变量时,其为每个使用该变量的线程提供独立的变量副本,因此每一个线程都可以独立改变自己的副本,而不会影响其他线程对应的副本。 ThreadLocal 内部实现机制:
(9)Atomic 关键字 答:可以使基本数据类型以原子的方式实现自增自减等操作,具体可参考我的博客:concurrent.atomic 包下的类 AtomicInteger 的使用。 (10)对线程池有了解吗?(必考) 答:
java.util.concurrent.ThreadPoolExecutor 类就是一个线程池。客户端调用 ThreadPoolExecutor.submit(Runnable task) 提交任务,线程池内部维护的工作者线程的数量就是该线程池的线程池大小,有 3 种形态:
(四)JVM 内存管理 既然是 Java 开发面试,那么对 JVM 的考察当然也是必须的,面试官一般会问对 JVM 是否有了解?我通常都会把我所了解的都说一遍,包括 JVM 内存划分、JVM 垃圾回收的含义、有哪些 GC 算法、年轻代和老年代各自的特点统统阐述一遍。 (1)JVM 内存划分
(2)类似 -Xms、-Xmn 这些参数的含义是什么 答: 堆内存分配:
非堆内存分配:
(3)垃圾回收算法有哪些? 答:
(4)root 搜索算法中,哪些可以作为 root? 答:
(5)GC 什么时候开始? 答:GC 经常发生的区域是堆区,堆区还可以细分为新生代、老年代,新生代还分为一个 Eden 区和两个 Survivor 区。
(6)内存泄漏和内存溢出 答: 概念:
内存泄漏的原因分析:
小结:本节涉及到 JVM 虚拟机,包括对内存的管理等知识,相对较深。除了以上问题,面试官会继续问一些比较深的问题,可能也是为了看看面试者的极限在哪里吧,比如内存调优、内存管理、是否遇到过内存泄漏的实际案例、是否真正关心过内存等。 (五)Java 8 相关知识点 关于 Java 8 中新知识点,面试官会让你说说对 Java 8 了解多少,下面主要阐述我所了解的,并且在面试中回答 Java 8 新增知识点。 (1)HashMap 的底层实现有变化:HashMap 是数组 + 链表 + 红黑树(JDK 1.8 增加了红黑树部分)实现。 (2)JVM 内存管理方面,由元空间代替了永久代。 区别:
(3)Lambda 表达式(也称为闭包),允许我们将函数当成参数传递给某个方法,或者把代码本身当做数据处理。 (4)函数式接口:指的是只有一个函数的接口,java.lang.Runnable 和
java.util.concurrent.Callable 就是函数式接口的例子;Java 8 提供了一个特殊的注解 @Functionallnterface 来标明该接口是一个函数式接口。 (5)引入重复注解:Java 8 中使用 @Repeatable 注解定义重复注解。 (6)接口中可以实现 default 方法。 (7) 注解的使用场景拓宽:注解几乎可以使用在任何元素上,局部变量、接口类型、超类和接口实现类,甚至可以用在函数的异常定义上。 (8) 新的包 java.time
小结:Java 8 的一些新特性,面试官一般情况下不要求你有多么精通,但需要有一些了解。 (六)网络协议相关 网络协议方面考察最多的包括服务器和客户端在三次握手、四次挥手过程中的状态变化,还有网络拥塞控制及其解决办法等。 (1)三次握手、四次挥手示意图
总共有四种状态:主动建立连接、主动断开连接、被动建立连和被动断开连接,两两组合还是 4 种组合。
SYNC_SENT----ESTABLISHED---FIN_WAIT_1---FIN_WAIT_2---TIME_WAIT
SYNC_SENT----ESTABLISHED---CLOSE_WAIT---LAST_ACK
LISTEN---SYN_RCVD---ESTABLISHED---FIN_WAIT_1---FIN_WAIT_2---TIME_WAIT
LISTEN---SYN_RCVD---ESTABLISHED---CLOSE_WAIT---LAST_ACK (2)滑动窗口机制 由发送方和接收方在三次握手阶段,互相将自己的最大可接收的数据量告诉对方,也就是自己的数据接收缓冲池的大小,这样对方可以根据已发送的数据量来计算是否可以接着发送。在处理过程中,当接收缓冲池的大小发生变化时,要给对方发送更新窗口大小的通知。 (3)拥塞避免机制 拥塞 对资源的需求超过了可用的资源,若网络中许多资源同时供应不足,网络的性能就要明显变坏,整个网络的吞吐量随之负荷的增大而下降。 拥塞控制 防止过多的数据注入到网络中,使得网络中的路由器或链路不致过载。 拥塞控制方法
(4)浏览器中输入:“www.xxx.com”之后都发生了什么?请详细阐述。 解析:经典的网络协议问题。 答:
寻找 IP 地址的过程依次经过了浏览器缓存、系统缓存、Hosts 文件、路由器缓存、 递归搜索根域名服务器。
(5)常见 HTTP 状态码
(6)TCP 和 UDP 的区别 答:
限于篇幅,关于更多网络协议相关知识,请参阅我的博客:TCP/IP 协议面试常问知识点,倾心总结。 小结:必须熟练掌握 TCP 和 UDP 的区别、三次握手和四次挥手的状态切换,必考。 (七)数据库知识点 既然是后端开发,那么与数据库相关的知识点也是必不可少的。 (1)MySQL 和 MongoDB 的区别有哪些?如何选择? (2)MongoDB 的优缺点有哪些? 我对这一块不是很熟悉,就不附上参考答案了,请各位小伙伴自行学习吧~ (3)听说过事务吗?(必考) 答:作为单个逻辑工作单元执行的一系列操作,满足四大特性:
(4)事务的并发问题有哪几种? 答:丢失更新、脏读、不可重复读和幻读。 (5)数据库中的锁有哪几种? 答:独占锁、排他锁和更新锁。 (6)事务的隔离级别有哪几种? 答:读未提交、读已提交、可重复读和序列化。 扩展问题:MySQL 事务默认隔离级别是哪个? 答:可重复读。 解析:关于问题(4)、(5)、(6)的详细解答,请参阅我的博客:数据库并发机制和事务的隔离级别详解。 关于数据库事务方面的深层次考察还有分布式事务即两段提交和三段提交等,限于我的水平,请大家自行学习。 (7)数据库的索引有什么作用?(必考)底层数据结构是什么,为什么使用这种数据结构? 答:
扩展问题:聚簇索引和非聚簇索引的区别? (8)MyISAM 和 InnoDB 的区别有哪些? 答:
最主要的区别是:MyISAM 表不支持事务、不支持行级锁、不支持外键。InnoDB 表支持事务、支持行级锁、支持外键。(可直接回答这个) (9)数据库中 where、group by、having 关键字 答: 关键字的作用:
having 和 where 的区别:
当同时含有 where 子句、group by 子句、having 子句及聚集函数时,执行顺序如下。
(10)还有一些问题,如 MySQL 和 SQL Server 用法上的区别、limit 关键字的使用等问题。 小结:数据库方面还是事务机制、隔离级别比较重要,当然了数据库索引是必考的问题。偶尔也会给你几个表,让你现场写 SQL 语句,主要考察 group by 和 having 等关键字。 (八)MVC 框架相关知识点 我在项目中使用的框架有 Spring MVC 和 MyBatis,因此在简历上只写了这两种框架,面试官主要针对这两种框架进行提问,以下问题供大家参考。 JavaWeb 开发经典的 3 层框架:Web 层、Service 层(业务逻辑层)和 Dao 层(数据访问层)。
Spring 知识点 (1)Spring 的 IoC 和 AOP 有了解吗? 答:
(2)AOP 的实现方式有哪几种?如何选择?(必考) 答:JDK 动态代理实现和 cglib 实现。 选择:
扩展:JDK 动态代理如何实现?(加分点) 答:JDK 动态代理,只能对实现了接口的类生成代理,而不是针对类,该目标类型实现的接口都将被代理。原理是通过在运行期间创建一个接口的实现类来完成对目标对象的代理。
解析:关于 IoC 和 AOP 的详细阐述,请参阅我的博客:Spring 核心 AOP(面向切面编程)总结,Spring 框架学习—控制反转(IoC)。 (3)Spring MVC 的核心控制器是什么?消息处理流程有哪些? 答:核心控制器为 DispatcherServlet,消息流程如下:
(4)其他问题包括:重定向和转发的区别、动态代理和静态代理的区别等。 MyBatis 知识点 关于 MyBatis 主要考察占位符 # 和 $ 的区别,区别如下:
(九)大数据相关知识点 大数据相关是因为我的简历上写了 KafKa 相关项目,所以面试官会进行提问 KafKa 相关知识点,我也进行了一些简单概念总结,深层次的实现原理因为并没有特别多的实战经验,所以并不了解。以下概念总结供大家参考。 (1)KafKa 基本特性 答:快速持久化、支持批量读写消息、支持消息分区,提高了并发能力、支持在线增加分区、支持为每个分区创建多个副本。 扩展:为什么可以实现快速持久化? 答:KafKa 将消息保存在磁盘中,并且读写磁盘的方式是顺序读写,避免了随机读写磁盘(寻道时间过长)导致的性能瓶颈;磁盘的顺序读写速度超过内存随机读写。 (2)核心概念 答:
副本(replica):
**消费者组(Consumer Group):**每个 consumer 都属于一个 consumer group,每条消息只能被 consumer group 中的一个 Consumer 消费,但可以被多个 consumer group 消费。 Broker
Cluster & Controller
保留策略和日志压缩
关于副本机制(加分点) ISR 集合:表示当前“可用”且消息量与 Leader 相差不多的副本集合,满足条件如下:
HW & LEO
ISR、HW 和 LEO 的工作配合
**KafKa 的容灾机制:**通过分区的副本 Leader 副本和 Follower 副本来提高容灾能力。 小结:请大家根据自己的简历自行准备学习大数据相关知识点。 (十)Linux 常见命令 我对这一方面不是很精通,知识点来源于网络总结以及面试官的提问,仅供大家参考。 (1)grep、sed 及 awk 命令 解析:awk 命令如果可以掌握,是面试中的一个加分点。 (2)文件和目录 pwd 显示当前目录。 ls 显示当前目录下的文件和目录:
(3)处理文件方面的命令有:touch、cp、 In、mv、rm (4)处理目录方面的命令:mkdir (5)查看文件内容:file、cat、more、less、tail、head (6)监测程序命令:ps、top eg.找出进程名中包括 Java 的所有进程:ps -ef | grep java。 top 命令:实时监测进程 top 命令输出的第一部分:显示系统的概括。
(7)ps 和 top 命令的区别:
(8) 压缩数据
(9)结束进程:kill PID 或者 kill all 至此,从十个不同的方面阐述了 Java 开发面试岗位中所涉及到的重要知识点。
大家一定要牢记,不能对背答案抗拒,毕竟我们是为了找到一份满意的工作,面试就是一场考试,我们总不能裸考吧!很多前辈帮我们梳理了 Java 面试中的核心知识点,尤其是 JavaGuide 的这份《Java 面试突击》,一定是复习的最好参照。
不好意思!GitHub 星标 100k+的这份面试攻略让我膨胀了
mp.weixin.qq.com/s/s0_XzGjHcgk2RwbCRzmgHgmp.weixin.qq.com
找工作是一场持久战,坚持到最后的才是胜利者。对于各位志在投身 Java 开发岗位的小伙伴们来说,本篇内容所提到的知识点绝对是面试中的重点,希望大家可以有效掌握。
需要java资料,面试合集的兄弟萌可以添加vx领取。vx号:TLXQXQ 添加时打好备注(8)领取资料。不然通过不了哦
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。