目錄:
框架是重點(diǎn)噩茄,但別讓人感覺你只會(huì)山寨別人的代碼
別只看單機(jī)版的框架,分布式也需要了解
對(duì)于數(shù)據(jù)庫(kù)向臀,別只知道增刪改查,得了解性能優(yōu)化
Java核心诸狭,圍繞數(shù)據(jù)結(jié)構(gòu)和性能優(yōu)化準(zhǔn)備面試題
Linux方面券膀,至少了解如何看日志排查問(wèn)題
通讀一段底層代碼君纫,作為加分項(xiàng)
切記切記,把上述技能嵌入到你的項(xiàng)目里
小結(jié):本文更多講述的準(zhǔn)備面試的方法
在上周芹彬,我密集面試了若干位Java后端的候選人蓄髓,工作經(jīng)驗(yàn)在3到5年間。
我的標(biāo)準(zhǔn)其實(shí)不復(fù)雜:
第一能干活
第二Java基礎(chǔ)要好
第三最好熟悉些分布式框架
相信其它公司招初級(jí)開發(fā)時(shí)舒帮,應(yīng)該也照著這個(gè)標(biāo)準(zhǔn)來(lái)面的会喝。
我也知道,不少候選人能力其實(shí)不差玩郊,但面試時(shí)沒準(zhǔn)備或不會(huì)說(shuō)肢执,這樣的人可能進(jìn)團(tuán)隊(duì)干活后確實(shí)能達(dá)到期望,但可能無(wú)法通過(guò)面試译红,面試官只根據(jù)面試情況來(lái)判斷预茄。
要知道,我們平時(shí)干活更偏重于業(yè)務(wù)侦厚,不可能大量接觸到算法耻陕,數(shù)據(jù)結(jié)構(gòu),底層代碼這類面試必問(wèn)的問(wèn)題點(diǎn)刨沦。
換句話說(shuō)诗宣,面試準(zhǔn)備點(diǎn)和平時(shí)工作要點(diǎn)匹配度很小。
?
作為面試官想诅,我只能根據(jù)候選人的回答來(lái)決定面試結(jié)果召庞。不過(guò),與人方便自己方便侧蘸。
所以我在本文里裁眯,將通過(guò)一些常用的問(wèn)題來(lái)介紹面試的準(zhǔn)備技巧。
大家在看后一定會(huì)感嘆:只要方法得當(dāng),準(zhǔn)備面試第一不難摇予,第二用的時(shí)間也不會(huì)太多宇整。
1、框架是重點(diǎn)逢艘,但別讓人感覺你只會(huì)山寨別人的代碼
在面試前,我會(huì)閱讀簡(jiǎn)歷以查看候選人在框架方面的項(xiàng)目經(jīng)驗(yàn)骤菠,在候選人的項(xiàng)目介紹的環(huán)節(jié)它改,我也會(huì)著重關(guān)注候選人最近的框架經(jīng)驗(yàn),目前比較熱門的是SSM商乎。
不過(guò)央拖,一般工作在5年內(nèi)的候選人,大多僅僅是能“山寨”別人的代碼,也就是說(shuō)能在現(xiàn)有框架的基礎(chǔ)上鲜戒,照著別人寫的流程专控,擴(kuò)展出新的功能模塊。
比如要寫個(gè)股票掛單的功能模塊遏餐,是會(huì)模仿現(xiàn)有的下單流程伦腐,然后從前端到后端再到數(shù)據(jù)庫(kù),依樣畫葫蘆寫一遍失都,最多把功能相關(guān)的代碼點(diǎn)改掉柏蘑。
其實(shí)我們每個(gè)人都這樣過(guò)來(lái)的,但在面試時(shí)粹庞,如果你僅僅表現(xiàn)出這樣的能力咳焚,就和大多數(shù)人的水平差不多了,在這點(diǎn)就沒法體現(xiàn)出你的優(yōu)勢(shì)了信粮。
我們知道黔攒,如果單純使用SSM框架,大多數(shù)項(xiàng)目都會(huì)有痛點(diǎn)强缘。比如數(shù)據(jù)庫(kù)性能差督惰,或者業(yè)務(wù)模塊比較復(fù)雜,并發(fā)量比較高旅掂,用Spring MVC里的Controller無(wú)法滿足跳轉(zhuǎn)的需求赏胚。
所以我一般還會(huì)主動(dòng)問(wèn):你除了依照現(xiàn)有框架寫業(yè)務(wù)代碼時(shí),還做了哪些改動(dòng)商虐?
我聽到的回答有:
增加了Redis緩存觉阅,以避免頻繁調(diào)用一些不變的數(shù)據(jù)。
或者秘车,在MyBitas的xml里典勇,select語(yǔ)句where條件有isnull,即這個(gè)值有就增加一個(gè)where條件叮趴,對(duì)此割笙,會(huì)對(duì)任何一個(gè)where增加一個(gè)不帶isnull的查詢條件,以免該語(yǔ)句當(dāng)傳入?yún)?shù)都是null時(shí)眯亦,做全表掃描伤溉。
或者干脆說(shuō),后端異步返回的數(shù)據(jù)量很大妻率,時(shí)間很長(zhǎng)乱顾,我在項(xiàng)目里就調(diào)大了異步返回的最大時(shí)間,或者對(duì)返回信息做了壓縮處理宫静,以增加網(wǎng)絡(luò)傳輸性能走净。
對(duì)于這個(gè)問(wèn)題券时,我不在乎聽到什么回答,我只關(guān)心回答符不符邏輯伏伯。一般只要答對(duì)革为,我就會(huì)給出“在框架層面有自己的體會(huì),有一定的了解”的面試評(píng)價(jià)舵鳞。
否則,我就只會(huì)給出“只能在項(xiàng)目經(jīng)理帶領(lǐng)下編寫框架代碼琢蛤,對(duì)框架本身了解不多”蜓堕。
其實(shí),在準(zhǔn)備面試時(shí)博其,歸納框架里的要點(diǎn)并不難套才,我就不信所有人在做項(xiàng)目時(shí)一點(diǎn)積累也沒,只要你說(shuō)出來(lái)慕淡,可以說(shuō)背伴,這方面你就碾壓了將近7成的競(jìng)爭(zhēng)者。
?
2峰髓、別只看單機(jī)版的框架傻寂,分布式也要了解
此外,在描述項(xiàng)目里框架技術(shù)時(shí)携兵,最好你再帶些分布式的技術(shù)疾掰。下面我列些大家可以準(zhǔn)備的分布式技術(shù)。
?
反向代理方面徐紧,nginx的基本配置静檬,比如如何通過(guò)lua語(yǔ)言設(shè)置規(guī)則,如何設(shè)置session粘滯并级。如果可以拂檩,再看些nginx的底層,比如協(xié)議嘲碧,集群設(shè)置稻励,失效轉(zhuǎn)移等。
遠(yuǎn)程調(diào)用dubbo方面呀潭,可以看下dubbo和zookeeper整合的知識(shí)點(diǎn)钉迷,再深一步,了解下dubbo底層的傳輸協(xié)議和序列化方式钠署。
消息隊(duì)列方面糠聪,可以看下kafka或任意一種組件的使用方式,簡(jiǎn)單點(diǎn)可以看下配置谐鼎,工作組的設(shè)置舰蟆,再深入點(diǎn)趣惠,可以看下Kafka集群,持久化的方式身害,以及發(fā)送消息是用長(zhǎng)連接還是短攔截味悄。
以上僅僅是用3個(gè)組件舉例,大家還可以看下Redis緩存塌鸯,日志框架侍瑟,MyCAT分庫(kù)分表等。
準(zhǔn)備的方式有兩大類:
第一是要會(huì)說(shuō)怎么用丙猬,這比較簡(jiǎn)單涨颜,能通過(guò)配置文件搭建成一個(gè)功能模塊即可
第二是可以適當(dāng)讀些底層代碼,以此了解下協(xié)議茧球,集群和失效轉(zhuǎn)移之類的高級(jí)知識(shí)點(diǎn)庭瑰。
如果能在面試中侃侃而談分布式組件的底層,那么得到的評(píng)價(jià)就會(huì)比較好了抢埋,比如“深入了解框架底層”弹灭,或“框架經(jīng)驗(yàn)豐富”,這樣就算去面試架構(gòu)師也行了揪垄,更何況是高級(jí)開發(fā)穷吮。
?在此我向大家推薦一個(gè)架構(gòu)學(xué)習(xí)交流群。交流學(xué)習(xí)圈:948368769里面會(huì)分享一些資深架構(gòu)師錄制的視頻錄像:有Spring饥努,MyBatis酒来,Netty源碼分析,高并發(fā)肪凛、高性能堰汉、分布式、微服務(wù)架構(gòu)的原理伟墙,JVM性能優(yōu)化翘鸭、分布式架構(gòu)等這些成為架構(gòu)師必備的知識(shí)體系。還能領(lǐng)取免費(fèi)的學(xué)習(xí)資源戳葵,目前受益良多
3就乓、對(duì)于數(shù)據(jù)庫(kù),別只知道增刪改查拱烁,得了解性能優(yōu)化
在實(shí)際項(xiàng)目里生蚁,大多數(shù)程序員用到的可能僅僅是增刪改查,當(dāng)我們用Mybatis時(shí)戏自,這個(gè)情況更普遍邦投。
不過(guò)如果你面試時(shí)也這樣表現(xiàn),估計(jì)你的能力就和其它競(jìng)爭(zhēng)者差不多了擅笔。
這方面志衣,你可以準(zhǔn)備如下的技能屯援。
SQL高級(jí)方面,比如group by, having念脯,左連接狞洋,子查詢(帶in),行轉(zhuǎn)列等高級(jí)用法绿店。
建表方面吉懊,你可以考慮下,你項(xiàng)目是用三范式還是反范式假勿,理由是什么惕它?
尤其是優(yōu)化,你可以準(zhǔn)備下如何通過(guò)執(zhí)行計(jì)劃查看SQL語(yǔ)句改進(jìn)點(diǎn)的方式废登,或者其它能改善SQL性能的方式(比如建索引等)。
如果你感覺有能力郁惜,還可以準(zhǔn)備些MySQL集群堡距,MyCAT分庫(kù)分表的技能。比如通過(guò)LVS+Keepalived實(shí)現(xiàn)MySQL負(fù)載均衡兆蕉,MyCAT的配置方式羽戒。同樣,如果可以虎韵,也看些相關(guān)的底層代碼易稠。
哪怕你在前三點(diǎn)表現(xiàn)一般,那么至少也能超越將近一半的候選人包蓝,尤其當(dāng)你在SQL優(yōu)化方面表現(xiàn)非常好驶社,那么你在面試高級(jí)開發(fā)時(shí),數(shù)據(jù)庫(kù)層面一定是達(dá)標(biāo)的测萎。
如果你連第四點(diǎn)也回答非常好亡电,那么恭喜你,你在數(shù)據(jù)庫(kù)方面的能力甚至達(dá)到了初級(jí)架構(gòu)的級(jí)別硅瞧。
?
4份乒、Java核心,圍繞數(shù)據(jù)結(jié)構(gòu)和性能優(yōu)化準(zhǔn)備面試題
Java核心這塊腕唧,網(wǎng)上的面試題很多或辖,不過(guò)在此之外,大家還應(yīng)當(dāng)著重關(guān)注集合(即數(shù)據(jù)結(jié)構(gòu))和多線程并發(fā)這兩塊
在此基礎(chǔ)上枣接,大家可以準(zhǔn)備些設(shè)計(jì)模式和虛擬機(jī)的說(shuō)辭颂暇。
下面列些我一般會(huì)問(wèn)的部分問(wèn)題:
String a = "123"; String b = "123"; a==b的結(jié)果是什么? 這包含了內(nèi)存但惶,String存儲(chǔ)方式等諸多知識(shí)點(diǎn)
HashMap里的hashcode方法和equal方法什么時(shí)候需要重寫蟀架?如果不重寫會(huì)有什么后果瓣赂?對(duì)此大家可以進(jìn)一步了解HashMap(甚至ConcurrentHashMap)的底層實(shí)現(xiàn)
ArrayList和LinkedList底層實(shí)現(xiàn)有什么差別?它們各自適用于哪些場(chǎng)合片拍?對(duì)此大家也可以了解下相關(guān)底層代碼煌集。
volatile關(guān)鍵字有什么作用?由此展開捌省,大家可以了解下線程內(nèi)存和堆內(nèi)存的差別苫纤。
CompletableFuture,這個(gè)是JDK1.8里的新特性纲缓,通過(guò)它怎么實(shí)現(xiàn)多線程并發(fā)控制卷拘?
JVM里,new出來(lái)的對(duì)象是在哪個(gè)區(qū)祝高?再深入一下栗弟,問(wèn)下如何查看和優(yōu)化JVM虛擬機(jī)內(nèi)存。
Java的靜態(tài)代理和動(dòng)態(tài)代理有什么差別工闺?最好結(jié)合底層代碼來(lái)說(shuō)乍赫。
通過(guò)上述的問(wèn)題點(diǎn),我其實(shí)不僅僅停留在“會(huì)用”級(jí)別陆蟆,比如我不會(huì)問(wèn)如何在ArrayList里放元素雷厂。
大家可以看到,上述問(wèn)題包含了“多線程并發(fā)”叠殷,“JVM優(yōu)化”改鲫,“數(shù)據(jù)結(jié)構(gòu)對(duì)象底層代碼”等細(xì)節(jié),大家也可以舉一反三林束,通過(guò)看一些高級(jí)知識(shí)像棘,多準(zhǔn)備些其它類似面試題。
我們知道壶冒,目前Java開發(fā)是以Web框架為主讲弄,那么為什么還要問(wèn)Java核心知識(shí)點(diǎn)呢?我這個(gè)是有切身體會(huì)的依痊。
之前在我團(tuán)隊(duì)里避除,我見過(guò)兩個(gè)人,一個(gè)是就會(huì)干活胸嘁,具體表現(xiàn)是會(huì)用Java核心基本的API瓶摆,而且也沒有深入了解的意愿(估計(jì)不知道該怎么深入了解),另一位平時(shí)專門會(huì)看些Java并發(fā)性宏,虛擬機(jī)等的高級(jí)知識(shí)群井。
過(guò)了半年以后,后者的能力快速升級(jí)到高級(jí)開發(fā)毫胜,由于對(duì)JAVA核心知識(shí)點(diǎn)了解很透徹书斜,所以看一些分布式組件的底層實(shí)現(xiàn)沒什么大問(wèn)題诬辈。 而前者,一直在重復(fù)勞動(dòng)荐吉,能力也只一直停留在“會(huì)干活”的層面焙糟。
而在現(xiàn)實(shí)的面試中,如果不熟悉Java核心知識(shí)點(diǎn)样屠,估計(jì)升高級(jí)開發(fā)都難穿撮,更別說(shuō)是面試架構(gòu)師級(jí)別的崗位了。
5痪欲、Linux方面悦穿,至少了解如何看日志排查問(wèn)題
如果候選人能證明自己有“排查問(wèn)題”和“解決問(wèn)題”的能力,這絕對(duì)是個(gè)加分項(xiàng)业踢,但怎么證明栗柒?
?
目前大多數(shù)的互聯(lián)網(wǎng)項(xiàng)目,都是部署在Linux上知举,也就是說(shuō)瞬沦,日志都是在Linux,下面歸納些實(shí)際的Linux操作负蠕。
能通過(guò)less命令打開文件,通過(guò)Shift+G到達(dá)文件底部倦畅,再通過(guò)?+關(guān)鍵字的方式來(lái)根據(jù)關(guān)鍵來(lái)搜索信息
能通過(guò)grep的方式查關(guān)鍵字遮糖,具體用法是, grep 關(guān)鍵字 文件名,如果要兩次在結(jié)果里查找的話叠赐,就用grep 關(guān)鍵字1 文件名 | 關(guān)鍵字2 --color欲账。最后--color是高亮關(guān)鍵字
能通過(guò)vi來(lái)編輯文件
能通過(guò)chmod來(lái)設(shè)置文件的權(quán)限
當(dāng)然,還有更多更實(shí)用的Linux命令芭概,但在實(shí)際面試過(guò)程中赛不,不少候選人連一條linux命令也不知道。還是這句話罢洲,你哪怕知道些很基本的踢故,也比一般人強(qiáng)了。
6惹苗、通讀一段底層代碼殿较,作為加分項(xiàng)
如何證明自己對(duì)一個(gè)知識(shí)點(diǎn)非常了解?莫過(guò)于能通過(guò)底層代碼來(lái)說(shuō)明。
我在和不少工作經(jīng)驗(yàn)在5年之內(nèi)的程序員溝通時(shí)桩蓉,不少人認(rèn)為這很難淋纲?確實(shí),如果要通過(guò)閱讀底層代碼了解分布式組件院究,那難度不小洽瞬,但如果如下部分的底層代碼本涕,并不難懂。
ArrayList,LinkedList的底層代碼里伙窃,包含著基于數(shù)組和鏈表的實(shí)現(xiàn)方式菩颖,如果大家能以此講清楚擴(kuò)容,“通過(guò)枚舉器遍歷“等方式对供,絕對(duì)能證明自己位他。
HashMap直接對(duì)應(yīng)著Hash表這個(gè)數(shù)據(jù)結(jié)構(gòu),在HashMap的底層代碼里产场,包含著hashcode的put鹅髓,get等的操作,甚至在ConcurrentHashMap里京景,還包含著Lock的邏輯窿冯。如果大家在面試中,看看而言ConcurrentHashMap确徙,再結(jié)合在紙上邊說(shuō)邊畫醒串,那一定能征服面試官。
可以看下靜態(tài)代理和動(dòng)態(tài)代理的實(shí)現(xiàn)方式鄙皇,再深入一下芜赌,可以看下Spring AOP里的實(shí)現(xiàn)代碼。
或許Spirng IOC和MVC的底層實(shí)現(xiàn)代碼比較難看懂伴逸,但大家可以說(shuō)些關(guān)鍵的類缠沈,根據(jù)關(guān)鍵流程說(shuō)下它們的實(shí)現(xiàn)方式。
其實(shí)準(zhǔn)備的底層代碼未必要多错蝴,而且也不限于在哪個(gè)方面洲愤,比如集合里基于紅黑樹的TreeSet,基于NIO的開源框架顷锰,甚至分布式組件的Dubbo柬赐,都可以準(zhǔn)備。
而且準(zhǔn)備時(shí)未必要背出所有的底層(事實(shí)上很難做到)官紫,你只要能結(jié)合一些重要的類和方法肛宋,講清楚思路即可(比如講清楚HashMap如何通過(guò)hashCode快速定位)。在此我向大家推薦一個(gè)架構(gòu)學(xué)習(xí)交流群束世。交流學(xué)習(xí)圈:948368769里面會(huì)分享一些資深架構(gòu)師錄制的視頻錄像:有Spring悼吱,MyBatis,Netty源碼分析良狈,高并發(fā)后添、高性能、分布式、微服務(wù)架構(gòu)的原理遇西,JVM性能優(yōu)化馅精、分布式架構(gòu)等這些成為架構(gòu)師必備的知識(shí)體系。還能領(lǐng)取免費(fèi)的學(xué)習(xí)資源粱檀,目前受益良多
那么在面試時(shí)洲敢,如何找到個(gè)好機(jī)會(huì)說(shuō)出你準(zhǔn)備好的上述底層代碼?
在面試時(shí)茄蚯,總會(huì)被問(wèn)到集合压彭,Spring MVC框架等相關(guān)知識(shí)點(diǎn),你在回答時(shí)渗常,順便說(shuō)一句壮不,“我還了解這塊的底層實(shí)現(xiàn)”,那么面試官一定會(huì)追問(wèn)皱碘,那么你就可以說(shuō)出來(lái)了询一。
不要小看這個(gè)對(duì)候選人的幫助,一旦你講了癌椿,只要意思到位健蕊,那么最少能得到個(gè)“積極專業(yè)“的評(píng)價(jià),如果描述很清楚踢俄,那么評(píng)價(jià)就會(huì)升級(jí)到“熟悉Java核心技能(或Spring MVC)缩功,且基本功扎實(shí)”。
要知道都办,面試中嫡锌,很少有人能講清楚底層代碼,所以你拋出了這個(gè)話題脆丁,哪怕最后沒達(dá)到預(yù)期效果世舰,面試官也不會(huì)由此對(duì)你降低評(píng)價(jià)动雹。
所以說(shuō)槽卫,準(zhǔn)備這塊絕對(duì)是“有百利而無(wú)一害”的掙錢買賣。
7胰蝠、切記切記歼培,把上述技能嵌入到你的項(xiàng)目里
在面試過(guò)程中,我經(jīng)常會(huì)聽到一些比較遺憾的回答茸塞,比如候選人對(duì)SQL優(yōu)化技能講得頭頭是道躲庄,但最后得知,這是他平時(shí)自學(xué)時(shí)掌握的钾虐,并沒用在實(shí)際項(xiàng)目里噪窘。
當(dāng)然這總比不說(shuō)要好,所以我會(huì)寫下“在平時(shí)自學(xué)過(guò)SQL優(yōu)化技能”效扫,但如果在項(xiàng)目里實(shí)踐過(guò)倔监,那么我就會(huì)寫下“有實(shí)際數(shù)據(jù)庫(kù)SQL優(yōu)化的技能”直砂。
大家可以對(duì)比下兩者的差別,一個(gè)是偏重理論浩习,一個(gè)是直接能干活了静暂。
其實(shí),很多場(chǎng)景里谱秽,我就不信在實(shí)際項(xiàng)目里一定沒有實(shí)踐過(guò)SQL優(yōu)化技能洽蛀。
從這個(gè)案例中,我想告訴大家的是疟赊,你之前費(fèi)了千辛萬(wàn)苦(其實(shí)方法方向得到郊供,也不用費(fèi)太大精力)準(zhǔn)備的很多技能和說(shuō)辭,最后應(yīng)該落實(shí)到你的實(shí)際項(xiàng)目里听绳。
比如你有過(guò)在Linux日志里查詢關(guān)鍵字排查問(wèn)題的經(jīng)驗(yàn)颂碘,在描述時(shí)你可以帶一句,在之前的項(xiàng)目里我就這樣干的椅挣。
又如头岔,你通過(guò)看底層代碼,了解了TreeSet和HashSet的差別以及它們的適用范圍鼠证,那么你可以回想你之前做的項(xiàng)目峡竣,是否有個(gè)場(chǎng)景僅僅適用于TreeSet?
如果有量九,那么你就可以適當(dāng)描述下項(xiàng)目的需求适掰,然后說(shuō),通過(guò)讀底層代碼荠列,我了解了兩者的差別类浪,而且在這個(gè)實(shí)際需求里,我就用了TreeSet肌似,而且我還專門做了對(duì)比性試驗(yàn)费就,發(fā)現(xiàn)用TreeSet比HashSet要高xx個(gè)百分點(diǎn)。
請(qǐng)記得川队,“實(shí)踐經(jīng)驗(yàn)”一定比“理論經(jīng)驗(yàn)”值錢力细,而且大多數(shù)你知道的理論上的經(jīng)驗(yàn),一定在你的項(xiàng)目里用過(guò)固额。
所以眠蚂,如果你僅僅讓面試官感覺你只有“理論經(jīng)驗(yàn)”,那就太虧了斗躏。
?
8逝慧、小結(jié):本文更多講述的準(zhǔn)備面試的方法
本文給出的面試題并不多,但本文并沒有打算給出太多的面試題。從本文里笛臣,大家更多看到的是面試官發(fā)現(xiàn)的諸多候選人的痛點(diǎn)栅干。
本文的用意是讓大家別再重蹈別人的覆轍,因此給出了不少準(zhǔn)備面試的方法捐祠。
你的能力或許比別人出眾碱鳞,但如果你準(zhǔn)備面試的方式和別人差不多,或者就拿你在項(xiàng)目里干的活來(lái)說(shuō)事踱蛀,而沒有歸納出你在項(xiàng)目中的亮點(diǎn)窿给,那么面試官還真的會(huì)看扁你。
End
作者:hsm_computer
來(lái)源:https://www.cnblogs.com/JavaArchitect/p/10011253.html
本文版權(quán)歸作者所有