分享我的面試經驗:網易的經典面試題

剛從網易面試回來,把我準備面試的經驗和遇到面試題總結在了一起,希望對你的職業生涯有有一定的幫助。

經驗分享

Java後端面試標準其實不復雜:第一能幹活,第二Java基礎要好,第三最好熟悉些分佈式框架。

其實,很多面試者能力其實不差,但面試時沒準備或不會說,這樣的人可能在進團隊幹活後確實能達到期望,但可能就無法通過面試,但面試官總是隻根據面試情況來判斷。

但現實情況是,大多數人可能面試前沒準備,或準備方法不得當。要知道,我們平時幹活更偏重於業務,不可能大量接觸到算法,數據結構,底層代碼這類面試必問的問題點,換句話說,面試準備點和平時工作要點匹配度很小。

在本文裏,將通過一些常用的問題來介紹面試的準備技巧。大家在看後一定會感嘆:只要方法得當,準備面試第一不難,第二用的時間也不會太多。

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

在面試前,面試官會閱讀簡歷以查看面試者在框架方面的項目經驗,在面試者的項目介紹的環節,面試官也會着重關注面試者最近的框架經驗,目前比較熱門的是SSM。

其實我們每個人都這樣過來的,但在面試時,如果你僅僅表現出這樣的能力,就和大多數人的水平差不多了,在這點就沒法體現出你的優勢了。

我們知道,如果單純使用SSM框架,大多數項目都會有痛點。比如數據庫性能差,或者業務模塊比較複雜,併發量比較高,用Spring MVC裏的Controller無法滿足跳轉的需求。所以面試官一般還會主動問:你除了依照現有框架寫業務代碼時,還做了哪些改動?

對於這個問題,面試官不在乎聽到什麼回答,面試官只關心回答符不符邏輯。一般只要答對,面試官就會給出“在框架層面有自己的體會,有一定的瞭解”,否則,面試官就只會給出“只能在項目經理帶領下編寫框架代碼,對框架本身瞭解不多”。

其實,在準備面試時,歸納框架裏的要點並不難,我就不信所有人在做項目時一點積累也沒,只要你說出來,可以說,這方面你就碾壓了將近7成的競爭者。

2. 別單純看單機版的框架,適當瞭解些分佈式

此外,在描述項目裏框架技術時,最好你再帶些分佈式的技術。

反向代理方面,nginx的基本配置,比如如何通過lua語言設置規則,如何設置session粘滯。如果可以,再看些nginx的底層,比如協議,集羣設置,失效轉移等。

遠程調用dubbo方面,可以看下dubbo和zookeeper整合的知識點,再深一步,瞭解下dubbo底層的傳輸協議和序列化方式。

消息隊列方面,可以看下kafka或任意一種組件的使用方式,簡單點可以看下配置,工作組的設置,再深入點,可以看下Kafka集羣,持久化的方式,以及發送消息是用長連接還是短攔截。

以上僅僅是用3個組件舉例,大家還可以看下Redis緩存,日誌框架,MyCAT分庫分表等。準備的方式有兩大類,第一是要會說怎麼用,這比較簡單,能通過配置文件搭建成一個功能模塊即可,第二是可以適當讀些底層代碼,以此瞭解下協議,集羣和失效轉移之類的高級知識點。

如果能在面試中侃侃而談分佈式組件的底層,那麼得到的評價就會比較好了,比如“深入瞭解框架底層”,或“框架經驗豐富”,這樣就算去面試架構師也行了,更何況是高級開發。

3. Java核心方面,圍繞數據結構和性能優化準備面試題

Java核心這塊,網上的面試題很多,不過在此之外,大家還應當着重關注集合(即數據結構)和多線程併發這兩塊,在此基礎上,大家可以準備些設計模式和虛擬機的說辭。

String a = "123"; String b = "123"; a==b的結果是什麼? 這包含了內存,String存儲方式等諸多知識點。

HashMap裏的hashcode方法和equal方法什麼時候需要重寫?如果不重寫會有什麼後果?對此大家可以進一步瞭解HashMap(甚至ConcurrentHashMap)的底層實現。

ArrayList和LinkedList底層實現有什麼差別?它們各自適用於哪些場合?對此大家也可以瞭解下相關底層代碼。

volatile關鍵字有什麼作用?由此展開,大家可以瞭解下線程內存和堆內存的差別。

CompletableFuture,這個是JDK1.8裏的新特性,通過它怎麼實現多線程併發控制?

JVM裏,new出來的對象是在哪個區?再深入一下,問下如何查看和優化JVM虛擬機內存。

Java的靜態代理和動態代理有什麼差別?最好結合底層代碼來說。

上述的問題,其實不僅僅只停留在“會用”級別,比如面試官不會問如何在ArrayList裏放元素。大家可以看到,上述問題包含了“多線程併發”,“JVM優化”,“數據結構對象底層代碼”等細節,大家也可以舉一反三,通過看一些高級知識,多準備些其它類似面試題。

4. 通讀一段底層代碼,作爲加分項

如何證明自己對一個知識點非常瞭解?莫過於能通過底層代碼來說明。

ArrayList,LinkedList的底層代碼裏,包含着基於數組和鏈表的實現方式,如果大家能以此講清楚擴容,“通過枚舉器遍歷“等方式,絕對能證明自己。

HashMap直接對應着Hash表這個數據結構,在HashMap的底層代碼裏,包含着hashcode的put,get等的操作,甚至在ConcurrentHashMap裏,還包含着Lock的邏輯。我相信,如果大家在面試中,看看而言ConcurrentHashMap,再結合在紙上邊說邊畫,那一定能征服面試官。

可以看下靜態代理和動態代理的實現方式,再深入一下,可以看下Spring AOP裏的實現代碼。

或許Spirng IOC和MVC的底層實現代碼比較難看懂,但大家可以說些關鍵的類,根據關鍵流程說下它們的實現方式。

不要小看這個,一旦你講了,只要意思到位,那麼最少能得到個“肯積極專業“的評價,如果描述很清楚,那麼評價就會升級到“熟悉Java核心技能(或Spring MVC),且基本功紮實”。要知道,面試中,很少有人能講清楚底層代碼,所以你拋出了這個話題,哪怕最後沒達到預期效果,面試官也不會由此對你降低評價。所以說,準備這塊絕對是“有百利而無一害”的掙錢買賣。

5. 一切的一切,把上述技能嵌入到你做過的項目裏

你之前費了千辛萬苦(其實方法方向得到,也不用費太大精力)準備的很多技能和說辭,最後應該落實到你的實際項目裏。

請記得,“實踐經驗”一定比“理論經驗”值錢,而且大多數你知道的理論上的經驗,一定在你的項目裏用過。所以,如果你僅僅讓面試官感覺你只有“理論經驗”,那就太虧了。


羣內提供免費的Java架構學習資料,QQ羣:643459718
(裏面有高可用、高併發、高性能及分佈式、Jvm性能調優、Spring源碼,
MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個知識點的架構資料)


 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章