“控制反转(IoC)”,站在面试官的角度聊聊Java面试。

在上周,我密集面试了若干位Java后端的候选人,工做经验在3到5年间。个人标准其实不复杂:第一能干活,第二Java基础要好,第三最好熟悉些分布式框架,我相信其它公司招初级开发时,应该也照着这个标准来面的。前端

我也知道,很多候选人能力其实不差,但面试时没准备或不会说,这样的人可能在进团队干活后确实能达到指望,但可能就没法经过面试,但面试官老是只根据面试状况来判断。linux

但现实状况是,大多数人可能面试前没准备,或准备方法不得当。要知道,咱们平时干活更偏重于业务,不可能大量接触到算法,数据结构,底层代码这类面试必问的问题点,换句话说,面试准备点和平时工做要点匹配度很小。nginx

做为面试官,我只能根据候选人的回答来决定面试结果。不过,与人方便本身方便,因此我在本文里,将经过一些经常使用的问题来介绍面试的准备技巧。程序员

你们在看后必定会感叹:只要方法得当,准备面试第一不难,第二用的时间也不会太多。面试

1 框架是重点,但别让人感受你只会山寨别人的代码算法

在面试前,我会阅读简历以查看候选人在框架方面的项目经验,在候选人的项目介绍的环节,我也会着重关注候选人最近的框架经验,目前比较热门的是SSM。数据库

不过,通常工做在5年内的候选人,大多仅仅是能“山寨”别人的代码,也就是说能在现有框架的基础上,照着别人写的流程,扩展出新的功能模块。后端

好比要写个股票挂单的功能模块,是会模仿现有的下单流程,而后从前端到后端再到数据库,依样画葫芦写一遍,最多把功能相关的代码点改掉。设计模式

其实咱们每一个人都这样过来的,但在面试时,若是你仅仅表现出这样的能力,就和大多数人的水平差很少了,在这点就无法体现出你的优点了。数组

咱们知道,若是单纯使用SSM框架,大多数项目都会有痛点。好比数据库性能差,或者业务模块比较复杂,并发量比较高,用Spring MVC里的Controller没法知足跳转的需求。

因此我通常还会主动问:你除了依照现有框架写业务代码时,还作了哪些改动?

我听到的回答有:

  • 增长了Redis缓存,以免频繁调用一些不变的数据
  • 或者在MyBitas的xml里,select语句where条件有isnull,即这个值有就增长一个where条件,对此,会对任何一个where增长一个不带isnull的查询条件,以避免该语句当传入参数都是null时,作全表扫描。
  • 或者干脆说,后端异步返回的数据量很大,时间很长,我在项目里就调大了异步返回的最大时间
  • 或者对返回信息作了压缩处理,以增长网络传输性能。

 

对于这个问题,我不在意听到什么回答,我只关心回答符不符逻辑。

通常只要答对,我就会给出“在框架层面有本身的体会,有必定的了解”,不然,我就只会给出“只能在项目经理带领下编写框架代码,对框架自己了解很少”。

 

其实,在准备面试时,概括框架里的要点并不难,我就不信全部人在作项目时一点积累也没,只要你说出来,能够说,这方面你就碾压了将近7成的竞争者。

2 别单纯看单机版的框架,适当了解些分布式

此外,在描述项目里框架技术时,最好你再带些分布式的技术。下面我列些你们能够准备的分布式技术。

 

“控制反转(IoC)”,站在面试官的角度聊聊Java面试

 

 

 

  1. 反向代理方面,nginx的基本配置,好比如何经过lua语言设置规则,如何设置session粘滞。若是能够,再看些nginx的底层,好比协议,集群设置,失效转移等。
  2. 远程调用dubbo方面,能够看下dubbo和zookeeper整合的知识点,再深一步,了解下dubbo底层的传输协议和序列化方式。
  3. 消息队列方面,能够看下kafka或任意一种组件的使用方式,简单点能够看下配置,工做组的设置,再深刻点,能够看下Kafka集群,持久化的方式,以及发送消息是用长链接仍是短拦截。

 

以上仅仅是用3个组件举例,你们还能够看下Redis缓存,日志框架,MyCAT分库分表等。

准备的方式有两大类:

  • 第一是要会说怎么用,这比较简单,能经过配置文件搭建成一个功能模块便可
  • 第二是能够适当读些底层代码,以此了解下协议,集群和失效转移之类的高级知识点。

 

若是能在面试中侃侃而谈分布式组件的底层,那么获得的评价就会比较好了,好比“深刻了解框架底层”,或“框架经验丰富”,这样就算去面试架构师也行了,更况且是高级开发。

3 数据库方面,别就知道增删改查,得了解性能优化

在实际项目里,大多数程序员用到的可能仅仅是增删改查,当咱们用Mybatis时,这个状况更广泛。

不过若是你面试时也这样表现,估计你的能力就和其它竞争者差很少了。

这方面,你能够准备以下的技能。

  1. SQL高级方面,好比group by, having,左链接,子查询(带in),行转列等高级用法。
  2. 建表方面,你能够考虑下,你项目是用三范式仍是反范式,理由是什么?
  3. 尤为是优化,你能够准备下如何经过执行计划查看SQL语句改进点的方式,或者其它能改善SQL性能的方式(好比建索引等)。
  4. 若是你感受有能力,还能够准备些MySQL集群,MyCAT分库分表的技能。好比经过LVS+Keepalived实现MySQL负载均衡,MyCAT的配置方式。一样,若是能够,也看些相关的底层代码。

 

哪怕你在前三点表现通常,那么至少也能超越将近通常的候选人,尤为当你在SQL优化方面表现很是好,那么你在面试高级开发时,数据库层面必定是达标的

若是你连第四点也回答很是好,那么恭喜你,你在数据库方面的能力甚至达到了初级架构的级别。

4 Java核心方面,围绕数据结构和性能优化准备面试题

Java核心这块,网上的面试题不少,不过在此以外,你们还应当着重关注集合(即数据结构)和多线程并发这两块

在此基础上,你们能够准备些设计模式和虚拟机的说辞。

下面列些我通常会问的部分问题:

  1. String a = "123"; String b = "123"; a==b的结果是什么?这包含了内存,String存储方式等诸多知识点。
  2. HashMap里的hashcode方法和equal方法何时须要重写?若是不重写会有什么后果?对此你们能够进一步了解HashMap(甚至ConcurrentHashMap)的底层实现。
  3. ArrayList和LinkedList底层实现有什么差异?它们各自适用于哪些场合?对此你们也能够了解下相关底层代码。
  4. volatile关键字有什么做用?由此展开,你们能够了解下线程内存和堆内存的差异。
  5. CompletableFuture,这个是JDK1.8里的新特性,经过它怎么实现多线程并发控制?
  6. JVM里,new出来的对象是在哪一个区?再深刻一下,问下如何查看和优化JVM虚拟机内存。
  7. Java的静态代理和动态代理有什么差异?最好结合底层代码来讲。

 

经过上述的问题点,我其实不只仅停留在“会用”级别,好比我不会问如何在ArrayList里放元素。

你们能够看到,上述问题包含了“多线程并发”,“JVM优化”,“数据结构对象底层代码”等细节

你们也能够触类旁通,经过看一些高级知识,多准备些其它相似面试题。

咱们知道,目前Java开发是以Web框架为主,那么为何还要问Java核心知识点呢?我这个是有切身体会的。

以前在我团队里,我见过两我的,一个是就会干活,具体表现是会用Java核心基本的API,并且也没有深刻了解的意愿,另外一位平时专门会看些Java并发,虚拟机等的高级知识。

过了半年之后,后者的能力快速升级到高级开发,因为对JAVA核心知识点了解很透彻,因此看一些分布式组件的底层实现没什么大问题。

而前者,一直在重复劳动,能力也只一直停留在“会干活”的层面。

而在现实的面试中,若是不熟悉Java核心知识点,估计升高级开发都难,更别说是面试架构师级别的岗位了。

5 Linux方面,至少了解如何看日志排查问题

若是候选人能证实本身有“排查问题”和“解决问题”的能力,这绝对是个加分项,但怎么证实?

目前大多数的互联网项目,都是部署在Linux上,也就是说,日志都是在Linux,下面概括些实际的Linux操做。

  1. 能经过less命令打开文件,经过Shift+G到达文件底部,再经过?+关键字的方式来根据关键来搜索信息。
  2. 能经过grep的方式查关键字,具体用法是, grep 关键字 文件名,若是要两次在结果里查找的话,就用grep 关键字1 文件名 | 关键字2 --color。最后--color是高亮关键字。
  3. 能经过vi来编辑文件。
  4. 能经过chmod来设置文件的权限。

 

固然,还有更多更实用的Linux命令,但在实际面试过程当中,很多候选人连一条linux命令也不知道。仍是这句话,你哪怕知道些很基本的,也比通常人强了。

6 通读一段底层代码,做为加分项

如何证实本身对一个知识点很是了解?莫过于能经过底层代码来讲明。我在和很多工做经验在5年以内的程序员沟通时,很多人认为这很难。

确实,若是要经过阅读底层代码了解分布式组件,那难度不小,但若是是以下部分的底层代码,并不难懂。

  1. ArrayList,LinkedList的底层代码里,包含着基于数组和链表的实现方式,若是你们能以此讲清楚扩容,“经过枚举器遍历“等方式,绝对能证实本身。
  2. HashMap直接对应着Hash表这个数据结构,在HashMap的底层代码里,包含着hashcode的put,get等的操做,甚至在ConcurrentHashMap里,还包含着Lock的逻辑。
  3. 我相信,若是你们在面试中,看看而言ConcurrentHashMap,再结合在纸上边说边画,那必定能征服面试官。
  4. 能够看下静态代理和动态代理的实现方式,再深刻一下,能够看下Spring AOP里的实现代码。
  5. 或许Spirng IOC和MVC的底层实现代码比较难看懂,但你们能够说些关键的类,根据关键流程说下它们的实现方式。

 

其实准备的底层代码未必要多,并且也不限于在哪一个方面,好比集合里基于红黑树的TreeSet,基于NIO的开源框架,甚至分布式组件的Dubbo,均可以准备。

并且准备时未必要背出全部的底层(事实上很难作到),你只要能结合一些重要的类和方法,讲清楚思路便可(好比讲清楚HashMap如何经过hashCode快速定位)。

那么在面试时,如何找到个好机会说出你准备好的上述底层代码?

在面试时,总会被问到集合,Spring MVC框架等相关知识点,你在回答时,顺便说一句,我还了解这块的底层实现”,那么面试官必定会追问,那么你就能够说出来了。

 

不要小看这个对候选人的帮助,一旦你讲了,只要意思到位,那么最少能获得个“肯积极专业“的评价

若是描述很清楚,那么评价就会升级到“熟悉Java核心技能(或Spring MVC),且基本功扎实”。

要知道,面试中,不多有人能讲清楚底层代码,因此你抛出了这个话题,哪怕最后没达到预期效果,面试官也不会由此对你下降评价。

因此说,准备这块绝对是“有百利而无一害”的挣钱买卖。

7 一切的一切,把上述技能嵌入到你作过的项目里

在面试过程当中,我常常会听到一些比较遗憾的回答,好比候选人对SQL优化技能讲得头头是道,但最后得知,这是他平时自学时掌握的,并没用在实际项目里。

固然这总比不说要好,因此我会写下“在平时自学过SQL优化技能”,但若是在项目里实践过,那么我就会写下“有实际数据库SQL优化的技能”。

你们能够对比下二者的差异,一个是偏重理论,一个是直接能干活了。其实,不少场景里,我就不信在实际项目里必定没有实践过SQL优化技能。

从这个案例中,我想告诉你们的是,你以前费了千辛万苦(其实方法方向获得,也不用费太大精力)准备的不少技能和说辞,最后应该落实到你的实际项目里。

好比你有过在Linux日志里查询关键字排查问题的经验,在描述时你能够带一句,在以前的项目里我就这样干的。

又如,你经过看底层代码,了解了TreeSet和HashSet的差异以及它们的适用范围,那么你就能够回想下你以前作的项目,是否有个场景仅仅适用于TreeSet?

若是有,那么你就能够适当描述下项目的需求,而后说,经过读底层代码,我了解了二者的差异,并且在这个实际需求里,我就用了TreeSet,并且我还专门作了对比性试验,发现用TreeSet比HashSet要高xx个百分点。

请记得,“实践经验”必定比“理论经验”值钱,并且大多数你知道的理论上的经验,必定在你的项目里用过。

因此,若是你仅仅让面试官感受你只有“理论经验”,那就太亏了。

8 小结:本文更多讲述的准备面试的方法

本文给出的面试题并很少,但本文并无打算给出太多的面试题。从本文里,你们更多看到的是面试官发现的诸多候选人的痛点。

本文的用意是让你们别再重蹈别人的覆辙,这还不算,本文还给出了很多准备面试的方法

你的能力或许比别人出众,但若是你准备面试的方式和别人差很少,或者就拿你在项目里干的活来讲事,而没有概括出你在项目中的亮点,那么面试官还真的会看扁你。

分享一份面试宝典《Java核心知识点整理.pdf》“,覆盖了JVM、锁、高并发、反射、Spring原理、微服务、Zookeeper、数据库、数据结构等等”,还有Java208道面试题(含答案)加入群(Java填坑之路)659655594 便可免费获取到!

相关文章
相关标签/搜索