Java后端面試總結(jié)

在上周依溯,我密集面試了若干位Java后端的候選人胚泌,工作經(jīng)驗在3到5年間。我的標(biāo)準(zhǔn)其實不復(fù)雜:第一能干活逼肯,第二Java基礎(chǔ)要好耸黑,第三最好熟悉些分布式框架,我相信其它公司招初級開發(fā)時篮幢,應(yīng)該也照著這個標(biāo)準(zhǔn)來面的崎坊。

我也知道,不少候選人能力其實不差洲拇,但面試時沒準(zhǔn)備或不會說奈揍,這樣的人可能在進(jìn)團(tuán)隊干活后確實能達(dá)到期望曲尸,但可能就無法通過面試,但面試官總是只根據(jù)面試情況來判斷男翰。

但現(xiàn)實情況是另患,大多數(shù)人可能面試前沒準(zhǔn)備,或準(zhǔn)備方法不得當(dāng)蛾绎。要知道昆箕,我們平時干活更偏重于業(yè)務(wù),不可能大量接觸到算法租冠,數(shù)據(jù)結(jié)構(gòu)鹏倘,底層代碼這類面試必問的問題點,換句話說顽爹,面試準(zhǔn)備點和平時工作要點匹配度很小纤泵。

作為面試官,我只能根據(jù)候選人的回答來決定面試結(jié)果镜粤。不過捏题,與人方便自己方便,所以我在本文里肉渴,將通過一些常用的問題來介紹面試的準(zhǔn)備技巧公荧。大家在看后一定會感嘆:只要方法得當(dāng),準(zhǔn)備面試第一不難同规,第二用的時間也不會太多循狰。

1. 框架是重點,但別讓人感覺你只會山寨別人的代碼

在面試前券勺,我會閱讀簡歷以查看候選人在框架方面的項目經(jīng)驗晤揣,在候選人的項目介紹的環(huán)節(jié),我也會著重關(guān)注候選人最近的框架經(jīng)驗朱灿,目前比較熱門的是SSM昧识。

不過,一般工作在5年內(nèi)的候選人盗扒,大多僅僅是能“山寨”別人的代碼跪楞,也就是說能在現(xiàn)有框架的基礎(chǔ)上,照著別人寫的流程侣灶,擴(kuò)展出新的功能模塊甸祭。比如要寫個股票掛單的功能模塊,是會模仿現(xiàn)有的下單流程褥影,然后從前端到后端再到數(shù)據(jù)庫池户,依樣畫葫蘆寫一遍,最多把功能相關(guān)的代碼點改掉。

其實我們每個人都這樣過來的校焦,但在面試時赊抖,如果你僅僅表現(xiàn)出這樣的能力,就和大多數(shù)人的水平差不多了寨典,在這點就沒法體現(xiàn)出你的優(yōu)勢了氛雪。

我們知道,如果單純使用SSM框架耸成,大多數(shù)項目都會有痛點报亩。比如數(shù)據(jù)庫性能差,或者業(yè)務(wù)模塊比較復(fù)雜井氢,并發(fā)量比較高弦追,用Spring MVC里的Controller無法滿足跳轉(zhuǎn)的需求。所以我一般還會主動問:你除了依照現(xiàn)有框架寫業(yè)務(wù)代碼時花竞,還做了哪些改動劲件?

我聽到的回答有:增加了Redis緩存,以避免頻繁調(diào)用一些不變的數(shù)據(jù)左胞。或者举户,在MyBitas的xml里烤宙,select語句where條件有isnull,即這個值有就增加一個where條件躺枕,對此,會對任何一個where增加一個不帶isnull的查詢條件供填,以免該語句當(dāng)傳入?yún)?shù)都是null時拐云,做全表掃描〗或者叉瘩,干脆說,后端異步返回的數(shù)據(jù)量很大粘捎,時間很長薇缅,我在項目里就調(diào)大了異步返回的最大時間,或者對返回信息做了壓縮處理攒磨,以增加網(wǎng)絡(luò)傳輸性能泳桦。

對于這個問題,我不在乎聽到什么回答娩缰,我只關(guān)心回答符不符邏輯灸撰。一般只要答對,我就會給出“在框架層面有自己的體會,有一定的了解”浮毯,否則完疫,我就只會給出“只能在項目經(jīng)理帶領(lǐng)下編寫框架代碼,對框架本身了解不多”亲轨。

其實趋惨,在準(zhǔn)備面試時,歸納框架里的要點并不難惦蚊,我就不信所有人在做項目時一點積累也沒器虾,只要你說出來,可以說蹦锋,這方面你就碾壓了將近7成的競爭者兆沙。

2. 別單純看單機(jī)版的框架,適當(dāng)了解些分布式

此外莉掂,在描述項目里框架技術(shù)時葛圃,最好你再帶些分布式的技術(shù)。下面我列些大家可以準(zhǔn)備的分布式技術(shù)憎妙。

  1. 反向代理方面库正,nginx的基本配置,比如如何通過lua語言設(shè)置規(guī)則厘唾,如何設(shè)置session粘滯褥符。如果可以,再看些nginx的底層抚垃,比如協(xié)議喷楣,集群設(shè)置,失效轉(zhuǎn)移等鹤树。

  2. 遠(yuǎn)程調(diào)用dubbo方面铣焊,可以看下dubbo和zookeeper整合的知識點,再深一步罕伯,了解下dubbo底層的傳輸協(xié)議和序列化方式曲伊。

  3. 消息隊列方面,可以看下kafka或任意一種組件的使用方式追他,簡單點可以看下配置熊昌,工作組的設(shè)置,再深入點湿酸,可以看下Kafka集群婿屹,持久化的方式,以及發(fā)送消息是用長連接還是短攔截推溃。

以上僅僅是用3個組件舉例昂利,大家還可以看下Redis緩存,日志框架,MyCAT分庫分表等蜂奸。準(zhǔn)備的方式有兩大類犁苏,第一是要會說怎么用,這比較簡單扩所,能通過配置文件搭建成一個功能模塊即可围详,第二是可以適當(dāng)讀些底層代碼,以此了解下協(xié)議祖屏,集群和失效轉(zhuǎn)移之類的高級知識點助赞。

如果能在面試中侃侃而談分布式組件的底層,那么得到的評價就會比較好了袁勺,比如“深入了解框架底層”雹食,或“框架經(jīng)驗豐富”,這樣就算去面試架構(gòu)師也行了期丰,更何況是高級開發(fā)群叶。

3. 數(shù)據(jù)庫方面,別就知道增刪改查钝荡,得了解性能優(yōu)化

在實際項目里街立,大多數(shù)程序員用到的可能僅僅是增刪改查,當(dāng)我們用Mybatis時埠通,這個情況更普遍赎离。不過如果你面試時也這樣表現(xiàn),估計你的能力就和其它競爭者差不多了植阴。

這方面蟹瘾,你可以準(zhǔn)備如下的技能圾浅。

  1. SQL高級方面掠手,比如group by, having,左連接狸捕,子查詢(帶in)喷鸽,行轉(zhuǎn)列等高級用法。

  2. 建表方面灸拍,你可以考慮下做祝,你項目是用三范式還是反范式,理由是什么鸡岗?

  3. 尤其是優(yōu)化混槐,你可以準(zhǔn)備下如何通過執(zhí)行計劃查看SQL語句改進(jìn)點的方式,或者其它能改善SQL性能的方式(比如建索引等)轩性。

  4. 如果你感覺有能力声登,還可以準(zhǔn)備些MySQL集群,MyCAT分庫分表的技能。比如通過LVS+Keepalived實現(xiàn)MySQL負(fù)載均衡悯嗓,MyCAT的配置方式件舵。同樣,如果可以脯厨,也看些相關(guān)的底層代碼铅祸。

哪怕你在前三點表現(xiàn)一般,那么至少也能超越將近一般的候選人合武,尤其當(dāng)你在SQL優(yōu)化方面表現(xiàn)非常好临梗,那么你在面試高級開發(fā)時,數(shù)據(jù)庫層面一定是達(dá)標(biāo)的眯杏,如果你連第四點也回答非常好夜焦,那么恭喜你,你在數(shù)據(jù)庫方面的能力甚至達(dá)到了初級架構(gòu)的級別岂贩。

4. Java核心方面茫经,圍繞數(shù)據(jù)結(jié)構(gòu)和性能優(yōu)化準(zhǔn)備面試題

Java核心這塊,網(wǎng)上的面試題很多萎津,不過在此之外卸伞,大家還應(yīng)當(dāng)著重關(guān)注集合(即數(shù)據(jù)結(jié)構(gòu))和多線程并發(fā)這兩塊,在此基礎(chǔ)上锉屈,大家可以準(zhǔn)備些設(shè)計模式和虛擬機(jī)的說辭荤傲。

下面列些我一般會問的部分問題:

  1. String a = "123"; String b = "123"; a==b的結(jié)果是什么? 這包含了內(nèi)存颈渊,String存儲方式等諸多知識點遂黍。

  2. HashMap里的hashcode方法和equal方法什么時候需要重寫?如果不重寫會有什么后果俊嗽?對此大家可以進(jìn)一步了解HashMap(甚至ConcurrentHashMap)的底層實現(xiàn)雾家。

  3. ArrayList和LinkedList底層實現(xiàn)有什么差別?它們各自適用于哪些場合绍豁?對此大家也可以了解下相關(guān)底層代碼芯咧。

  4. volatile關(guān)鍵字有什么作用?由此展開竹揍,大家可以了解下線程內(nèi)存和堆內(nèi)存的差別敬飒。

  5. CompletableFuture,這個是JDK1.8里的新特性芬位,通過它怎么實現(xiàn)多線程并發(fā)控制无拗?

  6. JVM里,new出來的對象是在哪個區(qū)昧碉?再深入一下英染,問下如何查看和優(yōu)化JVM虛擬機(jī)內(nèi)存阴孟。

  7. Java的靜態(tài)代理和動態(tài)代理有什么差別?最好結(jié)合底層代碼來說税迷。

通過上述的問題點永丝,我其實不僅僅停留在“會用”級別,比如我不會問如何在ArrayList里放元素箭养。大家可以看到慕嚷,上述問題包含了“多線程并發(fā)”,“JVM優(yōu)化”毕泌,“數(shù)據(jù)結(jié)構(gòu)對象底層代碼”等細(xì)節(jié)喝检,大家也可以舉一反三,通過看一些高級知識撼泛,多準(zhǔn)備些其它類似面試題挠说。

我們知道,目前Java開發(fā)是以Web框架為主愿题,那么為什么還要問Java核心知識點呢损俭?我這個是有切身體會的。

之前在我團(tuán)隊里潘酗,我見過兩個人杆兵,一個是就會干活,具體表現(xiàn)是會用Java核心基本的API仔夺,而且也沒有深入了解的意愿(估計不知道該怎么深入了解)琐脏,另一位平時專門會看些Java并發(fā),虛擬機(jī)等的高級知識缸兔。過了半年以后日裙,后者的能力快速升級到高級開發(fā),由于對JAVA核心知識點了解很透徹惰蜜,所以看一些分布式組件的底層實現(xiàn)沒什么大問題昂拂。 而前者,一直在重復(fù)勞動蝎抽,能力也只一直停留在“會干活”的層面政钟。

而在現(xiàn)實的面試中路克,如果不熟悉Java核心知識點樟结,估計升高級開發(fā)都難,更別說是面試架構(gòu)師級別的崗位了精算。

5. Linux方面瓢宦,至少了解如何看日志排查問題

如果候選人能證明自己有“排查問題”和“解決問題”的能力,這絕對是個加分項灰羽,但怎么證明驮履?

目前大多數(shù)的互聯(lián)網(wǎng)項目鱼辙,都是部署在Linux上,也就是說玫镐,日志都是在Linux倒戏,下面歸納些實際的Linux操作。

  1. 能通過less命令打開文件恐似,通過Shift+G到達(dá)文件底部杜跷,再通過?+關(guān)鍵字的方式來根據(jù)關(guān)鍵來搜索信息。

  2. 能通過grep的方式查關(guān)鍵字矫夷,具體用法是, grep 關(guān)鍵字 文件名葛闷,如果要兩次在結(jié)果里查找的話,就用grep 關(guān)鍵字1 文件名 | 關(guān)鍵字2 --color双藕。最后--color是高亮關(guān)鍵字淑趾。

  3. 能通過vi來編輯文件。

  4. 能通過chmod來設(shè)置文件的權(quán)限忧陪。

當(dāng)然扣泊,還有更多更實用的Linux命令,但在實際面試過程中嘶摊,不少候選人連一條linux命令也不知道旷赖。還是這句話,你哪怕知道些很基本的更卒,也比一般人強(qiáng)了等孵。

6. 通讀一段底層代碼,作為加分項

如何證明自己對一個知識點非常了解?莫過于能通過底層代碼來說明蹂空。我在和不少工作經(jīng)驗在5年之內(nèi)的程序員溝通時俯萌,不少人認(rèn)為這很難?確實上枕,如果要通過閱讀底層代碼了解分布式組件咐熙,那難度不小,但如果如下部分的底層代碼辨萍,并不難懂棋恼。

  1. ArrayList,LinkedList的底層代碼里,包含著基于數(shù)組和鏈表的實現(xiàn)方式锈玉,如果大家能以此講清楚擴(kuò)容爪飘,“通過枚舉器遍歷“等方式,絕對能證明自己拉背。

  2. HashMap直接對應(yīng)著Hash表這個數(shù)據(jù)結(jié)構(gòu)师崎,在HashMap的底層代碼里,包含著hashcode的put椅棺,get等的操作犁罩,甚至在ConcurrentHashMap里齐蔽,還包含著Lock的邏輯。我相信床估,如果大家在面試中含滴,看看而言ConcurrentHashMap,再結(jié)合在紙上邊說邊畫丐巫,那一定能征服面試官蛙吏。

  3. 可以看下靜態(tài)代理和動態(tài)代理的實現(xiàn)方式,再深入一下鞋吉,可以看下Spring AOP里的實現(xiàn)代碼鸦做。

  4. 或許Spirng IOC和MVC的底層實現(xiàn)代碼比較難看懂,但大家可以說些關(guān)鍵的類谓着,根據(jù)關(guān)鍵流程說下它們的實現(xiàn)方式泼诱。

其實準(zhǔn)備的底層代碼未必要多,而且也不限于在哪個方面赊锚,比如集合里基于紅黑樹的TreeSet治筒,基于NIO的開源框架,甚至分布式組件的Dubbo舷蒲,都可以準(zhǔn)備耸袜。而且準(zhǔn)備時未必要背出所有的底層(事實上很難做到),你只要能結(jié)合一些重要的類和方法牲平,講清楚思路即可(比如講清楚HashMap如何通過hashCode快速定位)堤框。

那么在面試時,如何找到個好機(jī)會說出你準(zhǔn)備好的上述底層代碼纵柿?在面試時蜈抓,總會被問到集合,Spring MVC框架等相關(guān)知識點昂儒,你在回答時沟使,順便說一句,“我還了解這塊的底層實現(xiàn)”渊跋,那么面試官一定會追問腊嗡,那么你就可以說出來了。

不要小看這個對候選人的幫助拾酝,一旦你講了燕少,只要意思到位,那么最少能得到個“肯積極專業(yè)“的評價微宝,如果描述很清楚棺亭,那么評價就會升級到“熟悉Java核心技能(或Spring MVC)虎眨,且基本功扎實”蟋软。要知道镶摘,面試中,很少有人能講清楚底層代碼岳守,所以你拋出了這個話題凄敢,哪怕最后沒達(dá)到預(yù)期效果,面試官也不會由此對你降低評價湿痢。所以說涝缝,準(zhǔn)備這塊絕對是“有百利而無一害”的掙錢買賣。

7. 一切的一切譬重,把上述技能嵌入到你做過的項目里

在面試過程中拒逮,我經(jīng)常會聽到一些比較遺憾的回答,比如候選人對SQL優(yōu)化技能講得頭頭是道臀规,但最后得知滩援,這是他平時自學(xué)時掌握的,并沒用在實際項目里塔嬉。

當(dāng)然這總比不說要好玩徊,所以我會寫下“在平時自學(xué)過SQL優(yōu)化技能”,但如果在項目里實踐過谨究,那么我就會寫下“有實際數(shù)據(jù)庫SQL優(yōu)化的技能”恩袱。大家可以對比下兩者的差別,一個是偏重理論胶哲,一個是直接能干活了畔塔。其實,很多場景里鸯屿,我就不信在實際項目里一定沒有實踐過SQL優(yōu)化技能俩檬。

從這個案例中,我想告訴大家的是碾盟,你之前費了千辛萬苦(其實方法方向得到棚辽,也不用費太大精力)準(zhǔn)備的很多技能和說辭,最后應(yīng)該落實到你的實際項目里冰肴。

比如你有過在Linux日志里查詢關(guān)鍵字排查問題的經(jīng)驗屈藐,在描述時你可以帶一句,在之前的項目里我就這樣干的熙尉。又如联逻,你通過看底層代碼,了解了TreeSet和HashSet的差別以及它們的適用范圍检痰,那么你就可以回想下你之前做的項目包归,是否有個場景僅僅適用于TreeSet?如果有铅歼,那么你就可以適當(dāng)描述下項目的需求公壤,然后說换可,通過讀底層代碼,我了解了兩者的差別厦幅,而且在這個實際需求里沾鳄,我就用了TreeSet,而且我還專門做了對比性試驗确憨,發(fā)現(xiàn)用TreeSet比HashSet要高xx個百分點译荞。

請記得,“實踐經(jīng)驗”一定比“理論經(jīng)驗”值錢休弃,而且大多數(shù)你知道的理論上的經(jīng)驗吞歼,一定在你的項目里用過。所以塔猾,如果你僅僅讓面試官感覺你只有“理論經(jīng)驗”浆熔,那就太虧了。

8. 小結(jié):本文更多講述的準(zhǔn)備面試的方法

本文給出的面試題并不多桥帆,但本文并沒有打算給出太多的面試題医增。從本文里,大家更多看到的是面試官發(fā)現(xiàn)的諸多候選人的痛點老虫。

本文的用意是讓大家別再重蹈別人的覆轍叶骨,這還不算,本文還給出了不少準(zhǔn)備面試的方法祈匙。你的能力或許比別人出眾忽刽,但如果你準(zhǔn)備面試的方式和別人差不多,或者就拿你在項目里干的活來說事夺欲,而沒有歸納出你在項目中的亮點跪帝,那么面試官還真的會看扁你。

原文可見:最近面試java后端開發(fā)的感受:如果就以平時項目經(jīng)驗來面試些阅,通過估計很難——再論面試前的準(zhǔn)備

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末伞剑,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子市埋,更是在濱河造成了極大的恐慌黎泣,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缤谎,死亡現(xiàn)場離奇詭異抒倚,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)坷澡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進(jìn)店門托呕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事项郊∠诳郏” “怎么了?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵呆抑,是天一觀的道長岂嗓。 經(jīng)常有香客問我汁展,道長鹊碍,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任食绿,我火速辦了婚禮侈咕,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘器紧。我一直安慰自己耀销,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布铲汪。 她就那樣靜靜地躺著熊尉,像睡著了一般。 火紅的嫁衣襯著肌膚如雪掌腰。 梳的紋絲不亂的頭發(fā)上狰住,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機(jī)與錄音齿梁,去河邊找鬼催植。 笑死,一個胖子當(dāng)著我的面吹牛勺择,可吹牛的內(nèi)容都是我干的创南。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼省核,長吁一口氣:“原來是場噩夢啊……” “哼稿辙!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起气忠,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤邓深,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后笔刹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體芥备,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年舌菜,在試婚紗的時候發(fā)現(xiàn)自己被綠了萌壳。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖袱瓮,靈堂內(nèi)的尸體忽然破棺而出缤骨,到底是詐尸還是另有隱情,我是刑警寧澤尺借,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布绊起,位于F島的核電站,受9級特大地震影響燎斩,放射性物質(zhì)發(fā)生泄漏虱歪。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一栅表、第九天 我趴在偏房一處隱蔽的房頂上張望笋鄙。 院中可真熱鬧,春花似錦怪瓶、人聲如沸萧落。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽找岖。三九已至,卻和暖如春敛滋,著一層夾襖步出監(jiān)牢的瞬間许布,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工矛缨, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留爹脾,地道東北人。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓箕昭,卻偏偏與公主長得像灵妨,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子落竹,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,044評論 2 355

推薦閱讀更多精彩內(nèi)容