大家好,我是小林。
愉快的周末又来了,虽然只有一天哈哈。
最近我逛博客园的时候,看到一篇 10 年工作经验的老哥被裁员之后面试高级 Java 开发工程师的求职经历!
他把自己面试过程中常见的知识也总结一下,我觉得非常干货,特此分享给大家,共勉!
概述
最近换工作,对最近面试的过程进行总结,总结每个公司的面试流程和问到的面试题,记录自己,也供大家参考。我是一名 Java 开发,工作经验 10 年,所以面试一名高级 Java 开发工程师。由于生鲜电商裁员,我也是受害者的一员,就职的公司是*菜。2021 年 9 月 8 号开始开始投简历,2021 年 9 月 18 号关闭 Boss 简历,去掉周末面试 8 天。投递数据
由于有复试原因,最多一天面试 6 家(超级赶,本来约了三家,但是来了 3 家复试,他们都要求最好能面了。给他们看了 Boss 预约信息,都要求插空一个小时)面试岗位情况
10 年 Java 经验,所以我投递是高级 Java 工程师的岗位。面试情况
Boss 面试截图
为了避免不必要的麻烦,这里把公司抹掉了,也只晒出了部分截图。Boss 预约的有 16 家,加起来总面试是 20 家。面试过程
本来打算每个都写一下面试过程来着,感觉有点流水账的意思了,没什么意思。这里挑几个典型介绍下。*送 :全程 10 分种多点,面试官全程没有表情。问的问题:Springboot 自动装配过程,Springboot 循环依赖,Springboot 自定义 start,hashmap。遇到过很多这种情况,问的问题也答了,面试官没有反应,继续问他的问题。一般遇到这种情况,不用惋惜也不要生气,他可能刚遇到啥生气的事情,或者性格就这样……(尽管这样安慰自己,当时也很生气哈哈)***水 :面试时长 1 个小时,问的问题:JVM/ArrayList/JMM 内存屏障,往深了问,比方 JMM 内存屏障怎么设计的,为什么要这么做……这种情况也比较多,有些大公司会这么问,这种除了自己生气,应该要好好看源码哈哈****r :明显的群面,让我生气的是,如果过了,你就往下进行就行,HR 说的很隐晦,就说前面两轮不错,要不来公司看看……猜测应该是她给很多人都这么说了,估计面试周期会很长,他们面试基数比较大,可能是 100 个人里找 2 个人哈哈****付 :面试流程明显有问题,应该也是群面的。去了 HR 先给我聊了半个多小时,大体问了工作经历,家庭情况,职业规划啥的,看起来是在拖延时间。一会叫来了业务总监,看看了工作经历。没有技术给我面试,最后 HR 说我们业务总监说你没有支付经验,所以不好意思。你怎么不一开始就问有没有支付经验,那样咱们就都不耽误时间。就是说这些吧,都是些负面的,希望大家不要遇到这种公司。面试结果
这次面试周期 10 天,面试 20 家,offer3 个,拒掉 2 个(直接没谈钱),还有一个再谈。也就是到谈钱的是 6 个。可能一开始有点慌,没有仔细筛选公司,所以面了几个没必要面的。面试高频
Java 基础
JVM :一般从 JVM 组成开始介绍,然后单独介绍每一块,然后就会慢慢衍生出垃圾回收方式,垃圾回收器,还可以衍生出 volatile 之类的,你也可以往自己重点掌握的去引导。重点:栈帧/堆,垃圾回收方式,垃圾回收器的对比 G1---CMS。unsafe 类 navicat 到 volatile。集合类:一般会问 HashMap 或者 arraylist,有的还会让比对 arraylist 和 linklist。ConcurrentHashMap 等一般回答初始化过程,组成,底层结构,算法,线程是否安全等,这块一定要回答仔细,要看过源码,或者看些 B 站的源码讲解很仔 细,到每一个方法名字,要是集合类就挂掉了,那就凉凉了……重点:hashmap 组成,寻找算法,扩容算法,put get 过程,红黑树二叉树 B+树的区别。锁:AQS 实现,公平锁/非公平锁,synchronized 和 lock 的区别,synchronized 锁演化过程一般从 AQS 谈起,这个和 HashMap 一样一定要通读源码,知道每一个方法的名字和过程,和集合类同样重要。即使没有问你,你最后也可以对比下 synchronized 和 lock 和 LockSupport,显得 JUC 下面都精通。还有这三个 CountDownLatch_CyclicBarrier_Semaphore,一般会问使用场景,要了然于胸CAS:通常搭配 volatile 问,我一般在上面几个回答中就带上了,这个应用比较广泛了,AQS,集合等大量使用,源码的时候直接说了就 OKThreadLocal:也是要看源码,还可以结合 4 大引用类型,堆内存泄漏使用,还有使用场景线程池:也是要看源码,还可以结合 4 大引用类型,堆内存泄漏使用,还有使用场景重点:7 大参数,拒绝策略。回答思路,7 大参数,拒绝策略介绍完。把线程池扩容场景描述一遍。结合实际使用场景说一下,参数配置,一个是耗 CPU 一个是耗 IO 的,应该就问题不大大体就写这么多,可能还有 JMM/JUC 下面的很多,就不一一列举了 。总结下:Java 基础是敲门砖,很多都要问源码,所以要非常熟悉,一般把这个当作一个开胃菜,回答好了,下面你才会自信,面试官也不 会鄙视你,否则即使往下问了,面试官也基本上给你判了死刑了,想想就知道多尴尬……Spring 相关
Spring 的问题问的也不少,但也不是很多,总结几个高频吧IOC/AOP/事务: 把它们归为一类吧,比较常问。一般就从理论谈到源码,然后加一些实际使用,具体方法。重点:IOC 的实现,也就是注册托管……,AOP 的实现逻辑方式的区别,AOP 的使用 ASpect 的增强方法的顺序。事务的传播方式。Spring 初始化 Bean 的过程: 可以在上面问题一块回答了。也有可能单独问你。这个要看源码,那几个状态,几个方法名字,bean 的 Scope,主要说 sigleton。里面有很多的设计模式也可以说下重点:三个 map,bean 的状态,scop 方式SpringBoot 自动装配 :Springboot 好像就这一个可以问的问题,所以要看源码,具体的哪个 reflsh 方法,要背下来。一般就说从注解说的简单的那种。要是还问,就要从 run 开始说了。我看过几遍,方法太多了,有些记不住呐…………MySql
索引: 一般这一个问题,你就可以把 mysql 的所有问题串一下。先说下 innodb 和 myisam,再说聚集索引/非聚集索引,B+树,索引覆盖,执行计划 expline,重点:聚集索引/非聚集索引的区别。B+树结构,怎么才能不回表。查询优化,覆盖索引。执行计划 expline 的参数。查询优化过程。最后查询优化还可以加上分库分表,这里面问的就更多了,分库分表方式,怎么能更快的读取,快速定位。要加上实际场景说,才有说服力……经典问题: 为什么不适用其他的树使用 B+树。这里还会和 hashmap 的红黑树比对。要看树的结构了,所以数据结构很重要。看了 B+树的结构就清楚了,我的理解 B+树叶子节点又加了一个类似数组的串了起来,范围查询的时候,就不用回树了,提高效率。非聚集索引怎么才能不回表 :非聚集索引存储的是索引内容+ID,当索引覆盖就不回表,这里就涉及到了联合索引的最左法制……,就说这么多,自己总结吧,太多了,你可以一直串着往下说,这样回答了问题,还进行了扩展,要不面试官也得往下问哈哈事务 :这个也是必问的,先从 ACID 说,然后用 undolog …保证的,然后隔离级别和出现的现象。然后再说隔离级别的底层,也就是 mysql 的锁,表锁行锁间隙锁,再到 MVCC重点:这里那几个隔离级别比较绕,要仔细看下,还有实际应用场景,否则很容易被问住。我这里卡过两个哈哈集群:主从复制,分片,分库分表。这里会问道集群搭建啥的,我一般就答一下分库分表相关的,偏运维的我还没有深入搞过,下面要学习了……Redis
redis 的数据类型: 5 大常用 3 个不常用的,然后结合使用场景都说下。
缓存问题和解决方案 :缓存雪崩,缓存击穿,缓存穿透。解决办法,多级缓存,布隆过滤器(黑白名单),万一击穿阻塞。这个是常见问题,可以结合你的项目说一下。一定不能挂,要不就凉凉……
淘汰策略 :几种淘汰策略介绍,然后说下 LRU 的算法实现(伪代码),看下 LRU 的算法,好多算法题就是手写 LRU 算法。
持久化 :RDB 和 AOF,使用场景,两种都用先用 AOF 恢复
集群 :主从/哨兵/分片,重点哨兵的介绍
重点:分布式锁 :这个是重点,可以再你的项目场景中就说了,分布式的一定涉及到这个问题。
结合下图的 5 个特性说,从 redisson 说到 redlock,重点就是下面五个特性和看门狗的实现,集群下的容错性。MQ
队列在分布式中应用广泛,所以这个一定会问,就算不问,你在说项目的时候也要说下应用场景MQ 的类型: direct/ topic/ fanout 分别的应用场景说一下
分布式下的应用: 说一下排对使用场景,然后围绕高可用进行说,发送端接收端如何保证消息的可靠性
延时队列: 这个被问到好多次,MQ 的实现是使用死信队列进行实现,两外两种一个是 redis+Springboot 实现,二是时间轮。这个是重点要好好看下,因为这个场景比较多,延时多久发信息,延时取消订单
还有问几个 MQ 的区别的或者问怎么选型的,我没回答太好,因为没有全都用过。微服务架构
微服务架构这个很重要,一般我都是在介绍项目的时候就介绍了,然后对几个框架进行对比回答技巧 :我一般从微服务的几大组成开始谈,然后对比他们的区别。到每一个技术的时候,说一下具体使用。比如:sentienl,先说下主要功能,然后结合项目怎么实现的,可以提一下 SentinelResource 的 blockHandler,这样让面试官知道是敲过代码的。然后说限流是根据什么配置的,熔断和降级解决什么实际问题分布式事务 :分布式事务放到这里说吧,这个致命重要,分布式下面常见场景,我一般放到这里讲。因为我准备的是 ailbaba 的 seate,大体说下分布式事务的几种方式,2pc 3pc。然后重点介绍自己项目使用的 seate,要说到 seate 服务使用表名字,怎么使用全局唯一 ID 和 3 大组件实现的,实现流程详细阐述,前置镜像后置镜像。最后说下优缺点,就齐活了…………算法/设计模式/Vue/项目经验/未来发展
设计模式可以准备一下,一般在 Spring 里面直接说了。要是面试官直接问,比方装饰模式是什么……我就跪了,看来还要全面的看一遍。至于项目经验/未来发展这些都要准备,因为即使一面不问,后面的面试也会被问到,所以要准备充分。总结
作为一名 Java 开发工程师,要学习的东西实在太多了,这里只是从 java 基础/Spring/Mysql/redis……这些方面总结下这几天被问到的高频面试题,记录自己,供大家参考………………面经总结
1、技术基础 :java 基础 数据库基础 缓存 中间件等,比如 hashMap 原理,数据库索引结构,redis 类型,mq 等。基础是敲门砖,最起码不能被这些问题给问住,如果超过两个基础你没有回答上来,一首凉凉送给你。2、算法题 :力扣,牛客,算法题还是要刷的,否则一个二叉树镜像你就挂了……我比较懒,没有刷这些题,所以遇到就挂了,等工作后一定要刷个 1k 道题哈哈3、微服务相关 :三个微服务框架 netfix,alibaba,dubbo+zk 的这些你都要了解过或者搞过,现在的技术,这些都是常用的,别说没搞过,要不又是一首凉凉……4、高大上的技术应用实例 :高大上的技术应用实例,一定要是通用场景(方便面试官往下问),你不要说一个只有行业才知道的技术使用场景,那就没得聊了。一定要是你技术的最高体现,高并发/高可用/微服务/缓存/事务这种技术的综合体现。当然准备好了是加分,要是没准备充分被问倒了就是减分项。比方我就是准备订单秒杀场景:这种场景包含上面提到的所有信息。可以聊的东西比较多。5、2 分钟内能介绍清楚的项目 :这个主要是在二面或者三面的时候高级别的面试官,考察你逻辑表达的能力。一般不用太复杂,但一定要是合情合理的业务场景,尽量大一点,完整的业务场景,不要说是某个边边角角。要使用简短的语言,通俗的话语说清楚。还要注意一点可以加上自己的项目负责人这一点,都说的这么透彻了,再加上负责人,面试官感觉你掌控项目没问题哈哈总结 :总结就上面这几点吧,虽然是我总结的,我也没有做的这么好,有很多一面就挂掉的,所以大家肯定比我优秀。原文:https://www.cnblogs.com/chenn/p/15337572.html