LZ常常思考自己的未來,也從自己的思考中總結出了一些東西,作為第一部分來談談。LZ認為一名程式設計師應該有幾個階段(以下時間都算上實習期): 第一階段-——三年 我認為三年對於程式設計師來說是第一個門檻,這個階段將會淘汰掉一批不適合寫程式碼的人。這一階段,我們走出校園,邁入社會,成為一名程式設計師,正式從書本上的內容邁向真正的企業級開發。 第二階段——五年 五年又是區分程式設計師的第二個門檻。有些人在三年裡,除了完成工作,在空餘時間基本不會研究別的東西,這些人永遠就是個Coder,年紀大一些勢必被更年輕的人給頂替;有些人在三年裡,除了寫程式碼之外,還熱衷於研究各種技術實現細節、看了N多好書、寫一些部落格、在Github上分享技術,這些人在五年後必然具備在技術上獨當一面的能力並且清楚自己未來的發展方向,從一個Coder逐步走向系統分析師或是架構師,成為專案組中不可或缺的人物。 第三階段——十年 十年又是另一個門檻了,轉行或是繼續做一名程式設計師就在這個節點上。如果在前幾年就抱定不轉行的思路並且為之努力的話,那麼在十年的這個節點上,有些人必然成長為一名對行業有著深入認識、對技術有著深入認識、能從零開始對一個產品進行分析的程式設計師,這樣的人在公司基本擔任的都是CTO、技術專家、首席架構師等最關鍵的職位,這對於自己絕對是一件榮耀的事,當然老闆在經濟上也絕不會虧待你。 一名3年工作經驗的Java程式設計師應該具備的技能,這可能是Java程式設計師們比較關心的內容。 1、基本語法 這包括static、final、transient等關鍵字的作用,foreach迴圈的原理等等。 今天面試我問你static關鍵字有哪些作 用,如果你答出static修飾變數、修飾方法我會認為你合格,答出靜態塊,我會認為你不錯,答出靜態內部類我會認為你很好,答出靜態導包我會對你很滿 意,因為能看出你非常熱衷研究技術。 2、集合 非常重要,也是必問的內容。基本上就是List、Map、Set,問的是各種實現類的底層實現原理,實現類的優缺點。 集合要掌握的是ArrayList、LinkedList、Hashtable、HashMap、ConcurrentHashMap、 HashSet的實現原理,能流利作答,當然能掌握CopyOnWrite容器和Queue是再好不過的了。另外多說一 句,ConcurrentHashMap的問題在面試中問得特別多,大概是因為這個類可以衍生出非常多的問題,關於ConcurrentHashMap, 我給網友朋友們提供三點回答或者是研究方向: (1) ConcurrentHashMap的鎖分段技術。 (2) ConcurrentHashMap的讀是否要加鎖,為什麼。 (3) ConcurrentHashMap的迭代器是強一致性的迭代器還是弱一致性的迭代器。 3、框架 老生常談,面試必問的東西。一般來說會問你一下你們專案中使用的框架,然後給你一些場景問你用框架怎麼做,比如我想要在Spring初始化bean 的時候做一些事情該怎麼做、想要在bean銷燬的時候做一些事情該怎麼做、MyBatis中$和#的區別等等,這些都比較實際了,平時積累得好、有多學習 框架的使用細節自然都不成問題。 如果上面你的問題答得好,面試官往往會深入地問一些框架的實現原理。 問得最多的就是Spring AOP的實現原理,當然這個很簡單啦,兩句話就搞定的的事兒,即使你不會準備一下就好了。我遇到的最變態的是讓我畫一下Spring的Bean工廠實 現的UML圖,當然面對這樣一個有深度的問題,我是答不出來的 4、資料庫 資料庫十有八九也都會問到。一些基本的像和 all的區別、left join、幾種索引及其區別就不談了,比較重要的就是資料庫效能的優化,如果對於資料庫的效能優化一竅不通,那麼有時間,還是建議你在面試前花一兩天專門 把SQL基礎和SQL優化的內容準備一下。 不過資料庫倒是不用擔心,一家公司往往有很多部門,如果你對資料庫不熟悉而基本技術又非常好,九成都是會要你的,估計會先把你放到對資料庫使用不是要求非常高的部門鍛鍊一下。 5、Web方面的一些問題 Java主要面向Web端,因此Web的一些問題也是必問的。 我碰到過問得最多的兩個問題是: 談談分散式Session的幾種實現方式。(大家可以聊下你們知道的實現方法) 常用的四種能答出來自然是讓面試官非常滿意的。 另外一個常問的問題是:講一下Session和Cookie的區別和聯絡以及Session的實現原理。 這兩個問題之外,web.xml裡面的內容是重點,Filter、Servlet、Listener,不說對它們的實現原理一清二楚吧,至少能對它們的使用知根知底。 另外,一些細節的方面比如get/post的區別、forward/重定向的區別、HTTPS的實現原理也都可能會被考察到。 6、資料結構和演算法分析 資料結構和演算法分析,對於一名程式設計師來說,會比不會好而且在工作中能派上用場。 陣列、連結串列是基礎,棧和佇列深入一些但也不難,樹挺重要的,比較 重要的樹AVL樹、紅黑樹,可以不瞭解它們的具體實現,但是要知道什麼是二叉查詢樹、什麼是平衡樹,AVL樹和紅黑樹的區別。 記得某次面試,某個面試官和 我聊到了資料庫的索引,他問我:你知道索引使用的是哪種資料結構實現嗎? 我答到用的Hash表吧,答錯。他又問,你知道為什麼要使用樹嗎?我答到因為Hash表可能會出現比較多的衝突,在千萬甚至是上億級別的資料面 前,會大大增加查詢的時間複雜度。 而樹比較穩定,基本保證最多二三十次就能找到想要的資料,對方說不完全對,最後我們還是交流了一下這個問題,我也明白了 為什麼要使用樹,這裡不說,網友朋友們覺得索引為什麼要使用樹來實現呢? 至於演算法分析,不會、不想研究就算了,記得某次面試對方問我,Collections.sort方法使用的是哪種排序方法,額,吐血三升。 當然為了 顯示我的博學,對演算法分析也有一定的研究(⊙﹏⊙)b,我還是硬著頭皮說了一句可能是氣泡排序吧。 當然答案肯定不是,有興趣的網友朋友們可以去看一下 Collections.sort方法的原始碼,用的是一種叫做TimSort的排序法,也就是增強型的歸併排序法。 7、Java虛擬機器 出乎我的意料,Java虛擬機器應該是很重要的一塊內容,結果在這幾家公司中被問到的概率幾乎為0。要知道,我去年可是花了大量的時間去研究Java虛擬機器的,光周志明老師的《深入理解Java虛擬機器:JVM高階特性與較佳實踐》,我就讀了不下五遍。 言歸正傳,雖然Java虛擬機器沒問到,但我覺得還是有必要研究的,我就簡單地列一個提綱吧,談談Java虛擬機器中比較重要的內容: (1) Java虛擬機器的記憶體佈局 (2) GC演算法及幾種垃圾收集器 (3) 類載入機制,也就是雙親委派模型 (4) Java記憶體模型 (5) happens-before規則 (6) volatile關鍵字使用規則 也許面試無用,但在走向大牛的路上,不可不會。 8、設計模式 本來以為蠻重要的一塊內容,結果只在阿里巴巴B2B事業部面試的時候被問了一次,當時問的是裝飾器模式。 當然我們們不能這麼功利,為了面試而學習,設計模式在工作中還是非常重要、非常有用的,23種設計模式中重點研究常用的十來種就可以了,面試中關於設計模式的問答主要是三個方向: (1) 你的專案中用到了哪些設計模式,如何使用。 (2) 知道常用設計模式的優缺點。 (3) 能畫出常用設計模式的UML圖。 9、多執行緒 這也是必問的一塊了。因為三年工作經驗,所以基本上不會再問你怎麼實現多執行緒了,會問得深入一些比如說Thread和Runnable的區別和聯 系、多次start一個執行緒會怎麼樣、執行緒有哪些狀態。 當然這只是最基本的,出乎意料地,幾次面試幾乎都被同時問到了一個問題,問法不盡相同。 總結起來是這麼一個意思: 假如有Thread1、Thread2、ThreaD3、Thread4四條執行緒分別統計C、D、E、F四個盤的大小,所有執行緒都統計完畢交給Thread5執行緒去做彙總,應當如何實現? 聰明的網友們對這個問題是否有答案呢?不難,java.util.concurrent下就有現成的類可以使用。(大家可以留言討論下用的什麼方法實現) 另外,執行緒池也是比較常問的一塊,常用的執行緒池有幾種?這幾種執行緒池之間有什麼區別和聯絡?執行緒池的實現原理是怎麼樣的? 實際一些的,會給你一些具體的場景,讓你回答這種場景該使用什麼樣的執行緒池比較合適。 最後,雖然這次面試問的不多,但是多執行緒同步、鎖這塊也是重點。synchronized和ReentrantLock的區別、 synchronized鎖普通方法和鎖靜態方法、死鎖的原理及排查方法等等。 10、JDK原始碼 要想拿高工資,JDK原始碼不可不讀。上面的內容可能還和具體場景聯絡起來,JDK原始碼就是實打實地看你平時是不是愛鑽研了。 我面試過程中被問了不 少JDK原始碼的問題,其中最刁鑽的一個問了我,String的hashCode()方法是怎麼實現的,幸好我平時String原始碼看得多,答了個大 概。 JDK原始碼其實沒什麼好總結的,純粹看個人,總結一下比較重要的原始碼: (1) List、Map、Set實現類的原始碼 (2) ReentrantLock、AQS的原始碼 (3) AtomicInteger的實現原理,主要能說清楚CAS機制並且AtomicInteger是如何利用CAS機制實現的 (4) 執行緒池的實現原理 (5) Object類中的方法以及每個方法的作用 最後,如果有興趣有時間,建議學習、研究一下SOA(面向服務程式設計)和RPC,面向服務體系,大型分散式架構必備,救命良方、包治百病、屢試不爽。
補充:
by licm 20200507
以上說的都是Java基礎底層,或者spring
目前流行的技術微服務,服務作為一個原子單位,服務間呼叫:
微服務:springboot,springcloud(裡面諸多元件,可以粗略認為是rpc)
中介軟體:redis,各種mq
分散式事務:tcc
。
。
。
再多的我也不知道了,不過我認為三年會這些應該很厲害了,lz目前一年半