面試之前先刷幾篇面經,或者做幾道熱門面試題,想必是大家很熟悉的一種複習方式了,就像我們當年經常做五年高考三年模擬一樣。但是可不要把面試題和麵經當成你的主要複習方式,它只是錦上添花,絕非雪中送炭!
壹面經的意義
面經是別人的面試經驗,所謂前車之鑑,後事之師。我們可以通過麵筋對自己的不足查缺補漏,卻不能把這些面試題等同於我們所要掌握的知識點。原因很簡單,兩篇面經可能會有很多的重複知識點,100篇面經也無法包含所有知識點,所以在只刷面經的問題就是:重複多、不全面。
其實筆者以前也很喜歡刷面經,在面試前幾天把該公司這個崗位的面經刷一遍,面試時還是可以遇到很多類似的問題的。這種做法短期內效果確實好,但是如果從長計議,只刷面經的複習方法實為下策。
作者在春招時才發現問題的嚴重性,吃了不少虧,簡單來說就是:別人的面試題和麵試總結看了又忘,忘了又看,本質性的東西沒有掌握。
貳你還記得多少面試題
在春招剛剛結束的這段時間,我總結了一下春招面試過程中的一些問題,主要就是:之前學過的東西忘記了很多,特別是那些理解的不夠深的知識點,總是特別容易忘記。另外我發現,雖然我在筆記中記錄了很多的知識點和麵試題,但是往往我只看過一次,不會再去看第二次。
這也意味著,雖然記錄的內容很多,但是真正消化吸收的內容很少,腦子裡充斥著總是那些零碎的知識點和麵試問題,對於完整的知識體系知之甚少。這些問題在春招期間也不斷地暴露出來,讓我思考了很久。
面對如此窘境,我想做出改變,趁著現在時間充裕,我想要為這些內容做一次減法,並且藉此機會,推翻自己原有的知識體系,重建新的知識框架。簡單說來,就是重新開始學習Java後端,這次我要用一種更高效的方式,避免走之前走的彎路,要用最高效,最合理的方式去複習。由於我之前已經有基礎,所以我對完成這一目標有信心,相應地我也為此做出了明確且詳細的學習計劃。
叄忘掉過去,重拾基礎
忘記過去,才能更好地開始。當然,也不是真的要大家忘記以前學過的知識點,只是建議各位把之前學的不紮實的技術重新地學一遍,不要只憑著印象去記憶知識點。
前面提到我在秋招前完成了知識體系重建,那在這裡我也想跟大家分享一下我當時大致的知識體系構成。就跟我前面說的一樣,我選擇重新再學一遍Java後端相關的技術內容,因為我知道大致的學習方向,並且有一定的基礎,所以看很多文章變得更加得心應手,寫文章和做總結也更加有底氣了。
首先在Java基礎方面,我寫了20多篇原創部落格,主要是對Java核心技術的解析,比如”Java反射”、”Java序列化和反序列化”、”Java異常體系”等等。
在Java集合類方面,我原創了部分文章,另外整合了一些比較好的技術文章,其中最主要的就是關於hashmap的文章,當時我整合的文章幾乎沒有遺漏任何一個知識點。
在Java併發程式設計方面,我主要參考了併發程式設計網以及一些優質部落格的文章,先搞懂了Java併發原理,再一步步學習JUC併發包的元件,其中重點看了chm,併發工具類以及阻塞佇列等JDK原始碼的解析文章,除此之外,我還會在IDE中跑JUC相關的emo,畢竟這方面的內容非常需要實踐。
在Java網路程式設計方面,我先從最基礎的socket入手,再講到NIO,AIO,並且加入了幾篇對Linux IO模型解析的文章,讓整個知識體系更加完整(因為NIO是基於Linux Epoll實現的),接著我又加入了對Netty的探討,以及Tomcat中對NIO的應用,可以說是把Java網路程式設計一些比較重要的部分都囊括進來了。為了更好理解這部分內容,我也在網上參考了很多客戶端和服務端通訊的demo,最後我分別用Socket,NIO,AIO以及Netty把C/S 通訊的demo都寫了一遍。
在JVM虛擬機器方面,我則按照《深入理解JVM虛擬機器》這本書的行文脈絡進行文章的整理。在搞定JVM基本原理以後,我著重瞭解了JVM調優和實踐中常遇到的問題,並且整理了常用的JVM調優工具,場景問題以及調優實踐的案例,這也是因為面試中對JVM調優實踐越來越重視了。
在JavaWeb方面,我從Java Web相關技術的發展入手,一步步瞭解了每種技術存在的意義,比如JSP,Servlet,JDBC,Spring等等,然後對每種技術進行了比較全面的瞭解,並且著重地看了Spring和SpringMVC的原始碼分析文章,另外一方面,我花了很多時間去研究Tomcat的工作原理。除此之外,JavaWeb專案中常用的maven,日誌元件,甚至是單測試元件,也納入了我的系列文章裡。
在資料庫和快取方面,我主要學習了MySQL和Redis這兩種最常用的資料庫。對於Mysql,我從簡單的sql開始瞭解,然後開始瞭解sql優化,MySQL的儲存引擎和索引,事務及鎖,還有更復雜的主從複製,分庫分表等內容。對於Redis,我也是從簡單的api入手,然後去了解每一種資料結構的底層實現原理,接著嘗試去學習Redis的持久化方式,以及作為快取常需要考慮的技術點,當然,也包括Redis的分散式鎖實現,以及它的分散式叢集方案。
最後一部分就是分散式相關的理論和技術了,這個也是困擾我很久的一塊內容,我主要把這塊內容分為兩個部分,分別是分散式理論和分散式技術,理論方面,我先了解CAP,BASE等基本知識,然後開始學習一致性協議和演算法,接著探討分散式事務。
對於分散式技術,涉及的東西就更多了,例如分散式session,負載均衡,分散式鎖等內容,這些知識點我都會用一到兩篇文章去總結,對於分散式快取,訊息佇列,以及分散式服務等內容,我會花比較多的時間去全面學習,然後總結出一個系列的文章出來。當然,對於這些技術的學習主要還是停留在理論方面,在自己的專案中能用到的比較少。
至此,我的知識體系基本構建完成,這也是我在秋招中能夠成功闖過那麼多面試的原因。
微信公眾號【程式設計師江湖】裡有什麼?
1.作者是收穫BAT頭條等大廠研發offer的求職老司機,後臺回覆“少俠”可以獲得我的微信,歡迎和我交流技術學習和求職心得。
2.每天早上九點分享一篇關於程式設計師成長與生活的文章,包括但不限於:求職攻略、學習方法、技術乾貨、成長感悟等方面的內容。
3.後臺回覆“資料”即可獲得3T海量學習資料,資料涵蓋各個技術方向,包括Java、C++、前端、大資料、移動開發等方向。對於每個方向,都包含了基礎、進階、求職等部分內容。
分享你最關心的技術、求職、成長與生活那些事