一名3年工做經驗的Java程序員應該具有的技能,這多是Java程序員們比較關心的內容。我這裏要說明一下,如下列舉的內容不是都要會的東西—-可是若是你掌握得越多,最終能獲得的評價、拿到的薪水勢必也越高。java
這包括static、final、transient等關鍵字的做用,foreach循環的原理等等。今天面試我問你static關鍵字有哪些做 用,若是你答出static修飾變量、修飾方法我會認爲你合格,答出靜態塊,我會認爲你不錯,答出靜態內部類我會認爲你很好,答出靜態導包我會對你很滿 意,由於能看出你很是熱衷研究技術。
最深刻的一次,我記得面試官直接問到了我Volatile關 鍵字的底層實現原理(順便插一句,面試和被面試自己就是相對的,面試官能問這個問題同時也讓面試者感受到面試官也是一個喜好研究技術的人,增長了面試者對 公司的好感,我最終選擇的就是問了這個問題的公司),不要以爲這太吹毛求疵了—-越簡單的問題越能看出一我的的水平,別人對你技術的考量絕大多數都是以深度優先、廣度次之爲標準的,切記。程序員
很是重要,也是必問的內容。基本上就是List、Map、Set,問的是各類實現類的底層實現原理,實現類的優缺點。
集合要掌握的是ArrayList、LinkedList、Hashtable、HashMap、ConcurrentHashMap、 HashSet的實現原理,能流利做答,固然能掌握CopyOnWrite容器和Queue是再好不過的了。另外多說一 句,ConcurrentHashMap的問題在面試中問得特別多,大概是由於這個類能夠衍生出很是多的問題,關於ConcurrentHashMap, 我給網友朋友們提供三點回答或者是研究方向:
(1)ConcurrentHashMap的鎖分段技術。
(2)ConcurrentHashMap的讀是否要加鎖,爲何。
(3)ConcurrentHashMap的迭代器是強一致性的迭代器仍是弱一致性的迭代器。web
老生常談,面試必問的東西。通常來講會問你一下大家項目中使用的框架,而後給你一些場景問你用框架怎麼作,好比我想要在Spring初始化bean 的時候作一些事情該怎麼作、想要在bean銷燬的時候作一些事情該怎麼作、MyBatis中$和#的區別等等,這些都比較實際了,平時積累得好、有多學習 框架的使用細節天然都不成問題。
若是上面你的問題答得好,面試官每每會深刻地問一些框架的實現原理。問得最多的就是Spring AOP的實現原理,固然這個很簡單啦,兩句話就搞定的的事兒,即便你不會準備一下就行了。我遇到的最變態的是讓我畫一下Spring的Bean工廠實 現的UML圖,固然面對這樣一個有深度的問題,我是答不出來的面試
數據庫十有八九也都會問到。一些基本的像和 all的區別、left join、幾種索引及其區別就不談了,比較重要的就是數據庫性能的優化,若是對於數據庫的性能優化一竅不通,那麼有時間,仍是建議你在面試前花一兩天專門 把SQL基礎和SQL優化的內容準備一下。
不過數據庫卻是不用擔憂,一家公司每每有不少部門,若是你對數據庫不熟悉而基本技術又很是好,九成都是會要你的,估計會先把你放到對數據庫使用不是要求很是高的部門鍛鍊一下。算法
Java主要面向Web端,所以Web的一些問題也是必問的。
我碰到過問得最多的兩個問題是:
談談分佈式Session的幾種實現方式。(你們能夠聊下大家知道的實現方法)
經常使用的四種能答出來天然是讓面試官很是滿意的。
另一個常問的問題是:講一下Session和Cookie的區別和聯繫以及Session的實現原理。這兩個問題以外,web.xml裏面的內容是重點,Filter、Servlet、Listener,不說對它們的實現原理一清二楚吧,至少能對它們的使用知根知底。另外,一些細節的方面好比get/post的區別、forward/重定向的區別、HTTPS的實現原理也均可能會被考察到。數據庫
數據結構和算法分析,對於一名程序員來講,會比不會好並且在工做中能派上用場。數組、鏈表是基礎,棧和隊列深刻一些但也不難,樹挺重要的,比較 重要的樹AVL樹、紅黑樹,能夠不瞭解它們的具體實現,可是要知道什麼是二叉查找樹、什麼是平衡樹,AVL樹和紅黑樹的區別。記得某次面試,某個面試官和 我聊到了數據庫的索引,他問我:你知道索引使用的是哪一種數據結構實現嗎?
我答到用的Hash表吧,答錯。他又問,你知道爲何要使用樹嗎?我答到由於Hash表可能會出現比較多的衝突,在千萬甚至是上億級別的數據面 前,會大大增長查找的時間複雜度。而樹比較穩定,基本保證最多二三十次就能找到想要的數據,對方說不徹底對,最後咱們仍是交流了一下這個問題,我也明白了 爲何要使用樹,這裏不說,網友朋友們以爲索引爲何要使用樹來實現呢?
至於算法分析,不會、不想研究就算了,記得某次面試對方問我,Collections.sort方法使用的是哪一種排序方法,額,吐血三升。固然爲了 顯示個人博學,對算法分析也有必定的研究(⊙﹏⊙)b,我仍是硬着頭皮說了一句多是冒泡排序吧。固然答案確定不是,有興趣的網友朋友們能夠去看一下 Collections.sort方法的源代碼,用的是一種叫作TimSort的排序法,也就是加強型的歸併排序法。設計模式
出乎個人意料,Java虛擬機應該是很重要的一塊內容,結果在這幾家公司中被問到的機率幾乎爲0。要知道,我去年但是花了大量的時間去研究Java虛擬機的,光周志明老師的《深刻理解Java虛擬機:JVM高級特性與較佳實踐》,我就讀了不下五遍。
言歸正傳,雖然Java虛擬機沒問到,但我以爲仍是有必要研究的,我就簡單地列一個提綱吧,談談Java虛擬機中比較重要的內容:
(1)Java虛擬機的內存佈局
(2)GC算法及幾種垃圾收集器
(3)類加載機制,也就是雙親委派模型
(4)Java內存模型
(5)happens-before規則
(6)volatile關鍵字使用規則
也許面試無用,但在走向大牛的路上,不可不會。數組
原本覺得蠻重要的一塊內容,結果只在阿里巴巴B2B事業部面試的時候被問了一次,當時問的是裝飾器模式。
固然我們不能這麼功利,爲了面試而學習,設計模式在工做中仍是很是重要、很是有用的,23種設計模式中重點研究經常使用的十來種就能夠了,面試中關於設計模式的問答主要是三個方向:
(1)你的項目中用到了哪些設計模式,如何使用。
(2)知道經常使用設計模式的優缺點。
(3)能畫出經常使用設計模式的UML圖。性能優化
這也是必問的一塊了。由於三年工做經驗,因此基本上不會再問你怎麼實現多線程了,會問得深刻一些好比說Thread和Runnable的區別和聯 系、屢次start一個線程會怎麼樣、線程有哪些狀態。固然這只是最基本的,出乎意料地,幾回面試幾乎都被同時問到了一個問題,問法不盡相同。
總結起來是 這麼一個意思:
假若有Thread一、Thread二、ThreaD三、Thread4四條線程分別統計C、D、E、F四個盤的大小,全部線程都統計完畢交給Thread5線程去作彙總,應當如何實現?
聰明的網友們對這個問題是否有答案呢?不難,java.util.concurrent下就有現成的類可使用。(你們能夠留言討論下用的什麼方法實現)
另外,線程池也是比較常問的一塊,經常使用的線程池有幾種?這幾種線程池之間有什麼區別和聯繫?線程池的實現原理是怎麼樣的?實際一些的,會給你一些具體的場景,讓你回答這種場景該使用什麼樣的線程池比較合適。
最後,雖然此次面試問得很少,可是多線程同步、鎖這塊也是重點。synchronized和ReentrantLock的區別、 synchronized鎖普通方法和鎖靜態方法、死鎖的原理及排查方法等等。數據結構
要想拿高工資,JDK源碼不可不讀。上面的內容可能還和具體場景聯繫起來,JDK源碼就是實打實地看你平時是否是愛鑽研了。我面試過程當中被問了不 少JDK源碼的問題,其中最刁鑽的一個問了我,String的hashCode()方法是怎麼實現的,幸虧我平時String源代碼看得多,答了個大 概。 JDK源碼其實沒什麼好總結的,純粹看我的,總結一下比較重要的源碼: (1)List、Map、Set實現類的源代碼 (2)ReentrantLock、AQS的源代碼 (3)AtomicInteger的實現原理,主要能說清楚CAS機制而且AtomicInteger是如何利用CAS機制實現的 (4)線程池的實現原理 (5)Object類中的方法以及每一個方法的做用 這些其實要求蠻高的,我去年一全年基本把JDK中重要類的源代碼研究了個遍,真的花費時間、花費精力,固然回頭看,是值得的—-不只僅是爲了應付面試。 最後,若是有興趣有時間,建議學習、研究一下SOA和RPC,面向服務體系,大型分佈式架構必備,救命良方、包治百病、屢試不爽。