第一階段:三年
我認(rèn)為三年對于程序員來說是第一個門檻文搂,這個階段將會淘汰掉一批不適合寫代碼的人适刀。這一階段,我們走出校園煤蹭,邁入社會笔喉,成為一名程序員,正式從書本 上的內(nèi)容邁向真正的企業(yè)級開發(fā)硝皂。我們知道如何團隊協(xié)作常挚、如何使用項目管理工具、項目版本如何控制稽物、我們寫的代碼如何測試如何在線上運行等等奄毡,積累了一定的 開發(fā)經(jīng)驗,也對代碼有了一定深入的認(rèn)識贝或,是一個比較純粹的Coder的階段
第二階段:五年
五年又是區(qū)分程序員的第二個門檻吼过。有些人在三年里锐秦,除了完成工作,在空余時間基本不會研究別的東西盗忱,這些人永遠就是個Coder酱床,年紀(jì)大一些勢必被 更年輕的人給頂替;有些人在三年里趟佃,除了寫代碼之外斤葱,還熱衷于研究各種技術(shù)實現(xiàn)細(xì)節(jié)、看了N多好書揖闸、寫一些博客、在Github上分享技術(shù)料身,這些人在五年 后必然具備在技術(shù)上獨當(dāng)一面的能力并且清楚自己未來的發(fā)展方向汤纸,從一個Coder逐步走向系統(tǒng)分析師或是架構(gòu)師,成為項目組中不可或缺的人物
第三階段:十年
十年又是另一個門檻了淌山,轉(zhuǎn)行或是繼續(xù)做一名程序員就在這個節(jié)點上助泽。如果在前幾年就抱定不轉(zhuǎn)行的思路并且為之努力的話居夹,那么在十年的這個節(jié)點上,有些 人必然成長為一名對行業(yè)有著深入認(rèn)識啃擦、對技術(shù)有著深入認(rèn)識、能從零開始對一個產(chǎn)品進行分析的程序員饿悬,這樣的人在公司基本擔(dān)任的都是CTO令蛉、技術(shù)專家、首席 架構(gòu)師等最關(guān)鍵的職位狡恬,這對于自己絕對是一件榮耀的事珠叔,當(dāng)然老板在經(jīng)濟上也絕不會虧待你
第一部分總結(jié)一下,我認(rèn)為弟劲,隨著你工作年限的增長祷安、對生活對生命認(rèn)識的深入,應(yīng)當(dāng)不斷思考三個問題:
1兔乞、我到底適不適合當(dāng)一名程序員汇鞭?
2、我到底應(yīng)不應(yīng)該一輩子以程序員為職業(yè)庸追?
3霍骄、我對編程到底持有的是一種什么樣的態(tài)度,是夠用就好呢還是不斷研究锚国?
最終腕巡,明確自己的職業(yè)規(guī)劃,對自己的規(guī)劃負(fù)責(zé)并為之努力血筑。
關(guān)于項目經(jīng)驗
LZ在網(wǎng)上經(jīng)郴娉粒看到一些別的朋友有提出項目經(jīng)驗的問題煎楣,依照LZ面試的感覺來說,面試主要看幾點:項目經(jīng)驗+基本技術(shù)+個人潛力(也就是值不值得培養(yǎng))车伞。
關(guān)于項目經(jīng)驗择懂,我認(rèn)為并發(fā)編程網(wǎng)的創(chuàng)始人方騰飛老師講的一段話非常好:
介紹產(chǎn)品時面試官會考察應(yīng)聘者的溝通能力和思考能力,我們大部分情況都是做產(chǎn)品的一個功能或一個模塊另玖,但是即使是這樣困曙,自 己有沒有把整個系統(tǒng)架構(gòu)或產(chǎn)品搞清楚,并能介紹清楚谦去,為什么做這個系統(tǒng)慷丽?這個系統(tǒng)的價值是什么?這個系統(tǒng)有哪些功能鳄哭?優(yōu)缺點有哪些要糊?如果讓你重新設(shè)計這個 系統(tǒng)你會如何設(shè)計?
我覺得這就已經(jīng)足以概括了妆丘。也許你僅僅工作一年锄俄,也許你做的是項目中微不足道的模塊,當(dāng)然這些一定是你的劣勢且無法改變勺拣,但是如何彌補這個劣勢奶赠,從方老師的話中我總結(jié)幾點:
1、明確你的項目到底是做什么的药有,有哪些功能
2毅戈、明確你的項目的整體架構(gòu),在面試的時候能夠清楚地畫給面試官看并且清楚地指出從哪里調(diào)用到哪里愤惰、使用什么方式調(diào)用
3竹祷、明確你的模塊在整個項目中所處的位置及作用
4、明確你的模塊用到了哪些技術(shù)羊苟,更好一些的可以再了解一下整個項目用到了哪些技術(shù)
在你無法改變自己的工作年限塑陵、自己的不那么有說服力的項目經(jīng)驗的情況下(這一定是扣分項),可以通過這種方式來一定程度上地彌補并且增進面試官對你的好感度蜡励。
關(guān)于專業(yè)技能
寫完項目接著寫寫一名3年工作經(jīng)驗的Java程序員應(yīng)該具備的技能令花,這可能是Java程序員們比較關(guān)心的內(nèi)容。我這里要說明一下凉倚,以下列舉的內(nèi)容不是都要會的東西—-但是如果你掌握得越多兼都,最終能得到的評價、拿到的薪水勢必也越高稽寒。
1扮碧、基本語法
這包括static、final、transient等關(guān)鍵字的作用慎王,foreach循環(huán)的原理等等蚓土。今天面試我問你static關(guān)鍵字有哪些作 用,如果你答出static修飾變量赖淤、修飾方法我會認(rèn)為你合格蜀漆,答出靜態(tài)塊,我會認(rèn)為你不錯咱旱,答出靜態(tài)內(nèi)部類我會認(rèn)為你很好确丢,答出靜態(tài)導(dǎo)包我會對你很滿 意,因為能看出你非常熱衷研究技術(shù)吐限。
最深入的一次鲜侥,LZ記得面試官直接問到了我Volatile關(guān) 鍵字的底層實現(xiàn)原理(順便插一句,面試和被面試本身就是相對的诸典,面試官能問這個問題同時也讓面試者感覺到面試官也是一個喜愛研究技術(shù)的人剃毒,增加了面試者對 公司的好感,LZ最終選擇的就是問了這個問題的公司)搂赋,不要覺得這太吹毛求疵了—-越簡單的問題越能看出一個人的水平,別人對你技術(shù)的考量絕大多數(shù)都是以深度****優(yōu)先益缠、廣度次之為標(biāo)準(zhǔn)的脑奠,切記。
2幅慌、集合
非常重要宋欺,也是必問的內(nèi)容∫任椋基本上就是List齿诞、Map、Set骂租,問的是各種實現(xiàn)類的底層實現(xiàn)原理祷杈,實現(xiàn)類的優(yōu)缺點。
集合要掌握的是ArrayList渗饮、LinkedList但汞、Hashtable、HashMap互站、ConcurrentHashMap私蕾、 HashSet的實現(xiàn)原理,能流利作答胡桃,當(dāng)然能掌握CopyOnWrite容器和Queue是再好不過的了踩叭。另外多說一 句,ConcurrentHashMap的問題在面試中問得特別多,大概是因為這個類可以衍生出非常多的問題容贝,關(guān)于ConcurrentHashMap自脯, 我給網(wǎng)友朋友們提供三點回答或者是研究方向:
(1)ConcurrentHashMap的鎖分段技術(shù)
(2)ConcurrentHashMap的讀是否要加鎖,為什么
(3)ConcurrentHashMap的迭代器是強一致性的迭代器還是弱一致性的迭代器
3嗤疯、設(shè)計模式
本來以為蠻重要的一塊內(nèi)容冤今,結(jié)果只在阿里巴巴B2B事業(yè)部面試的時候被問了一次,當(dāng)時問的是裝飾器模式茂缚。
當(dāng)然咱們不能這么功利戏罢,為了面試而學(xué)習(xí),設(shè)計模式在工作中還是非常重要脚囊、非常有用的龟糕,23種設(shè)計模式中重點研究常用的十來種就可以了,面試中關(guān)于設(shè)計模式的問答主要是三個方向:
(1)你的項目中用到了哪些設(shè)計模式悔耘,如何使用
(2)知道常用設(shè)計模式的優(yōu)缺點
(3)能畫出常用設(shè)計模式的UML圖
4讲岁、多線程
這也是必問的一塊了。因為三年工作經(jīng)驗衬以,所以基本上不會再問你怎么實現(xiàn)多線程了缓艳,會問得深入一些比如說Thread和Runnable的區(qū)別和聯(lián) 系、多次start一個線程會怎么樣看峻、線程有哪些狀態(tài)阶淘。當(dāng)然這只是最基本的,出乎意料地互妓,幾次面試幾乎都被同時問到了一個問題溪窒,問法不盡相同,總結(jié)起來是 這么一個意思:
假如有Thread1冯勉、Thread2澈蚌、ThreaD3、Thread4四條線程分別統(tǒng)計C灼狰、D宛瞄、E、F四個盤的大小交胚,所有線程都統(tǒng)計完畢交給Thread5線程去做匯總坛悉,應(yīng)當(dāng)如何實現(xiàn)?
聰明的網(wǎng)友們對這個問題是否有答案呢承绸?不難裸影,java.util.concurrent下就有現(xiàn)成的類可以使用。
另外军熏,線程池也是比較常問的一塊轩猩,常用的線程池有幾種?這幾種線程池之間有什么區(qū)別和聯(lián)系?線程池的實現(xiàn)原理是怎么樣的均践?實際一些的晤锹,會給你一些具體的場景,讓你回答這種場景該使用什么樣的線程池比較合適彤委。
最后鞭铆,雖然這次面試問得不多,但是多線程同步焦影、鎖這塊也是重點车遂。synchronized和ReentrantLock的區(qū)別、 synchronized鎖普通方法和鎖靜態(tài)方法斯辰、死鎖的原理及排查方法等等舶担,關(guān)于多線程,我在之前有些過文章總結(jié)過多線程的40個問題彬呻,可以參看40個Java多線程問題總結(jié)衣陶。
5、JDK源碼
要想拿高工資闸氮,JDK源碼不可不讀剪况。上面的內(nèi)容可能還和具體場景聯(lián)系起來,JDK源碼就是實打?qū)嵉乜茨闫綍r是不是愛鉆研了蒲跨。LZ面試過程中被問了不 少JDK源碼的問題译断,其中最刁鉆的一個問了LZ,String的hashCode()方法是怎么實現(xiàn)的财骨,幸好LZ平時String源代碼看得多,答了個大 概藏姐。JDK源碼其實沒什么好總結(jié)的隆箩,純粹看個人,總結(jié)一下比較重要的源碼:
(1)List羔杨、Map捌臊、Set實現(xiàn)類的源代碼
(2)ReentrantLock、AQS的源代碼
(3)AtomicInteger的實現(xiàn)原理兜材,主要能說清楚CAS機制并且AtomicInteger是如何利用CAS機制實現(xiàn)的
(4)線程池的實現(xiàn)原理
(5)Object類中的方法以及每個方法的作用
這些其實要求蠻高的理澎,LZ去年一整年基本把JDK中重要類的源代碼研究了個遍,真的花費時間曙寡、花費精力糠爬,當(dāng)然回頭看,是值得的—-不僅僅是為了應(yīng)付面試举庶。
6执隧、框架
老生常談,面試必問的東西。一般來說會問你一下你們項目中使用的框架镀琉,然后給你一些場景問你用框架怎么做峦嗤,比如我想要在Spring初始化bean 的時候做一些事情該怎么做、想要在bean銷毀的時候做一些事情該怎么做屋摔、MyBatis中$和#的區(qū)別等等烁设,這些都比較實際了,平時積累得好钓试、有多學(xué)習(xí) 框架的使用細(xì)節(jié)自然都不成問題装黑。
如果上面你的問題答得好,面試官往往會深入地問一些框架的實現(xiàn)原理亚侠。問得最多的就是Spring AOP的實現(xiàn)原理曹体,當(dāng)然這個很簡單啦,兩句話就搞定的的事兒硝烂,即使你不會準(zhǔn)備一下就好了箕别。LZ遇到的最變態(tài)的是讓LZ畫一下Spring的Bean工廠實 現(xiàn)的UML圖,當(dāng)然面對這樣一個有深度的問題滞谢,LZ是絕對答不出來的/(ㄒoㄒ)/~~
7串稀、數(shù)據(jù)庫
數(shù)據(jù)庫十有八九也都會問到。一些基本的像union和union all的區(qū)別狮杨、left join母截、幾種索引及其區(qū)別就不談了,比較重要的就是數(shù)據(jù)庫性能的優(yōu)化橄教,如果對于數(shù)據(jù)庫的性能優(yōu)化一竅不通清寇,那么有時間,還是建議你在面試前花一兩天專門 把SQL基礎(chǔ)和SQL優(yōu)化的內(nèi)容準(zhǔn)備一下护蝶。
不過數(shù)據(jù)庫倒是不用擔(dān)心华烟,一家公司往往有很多部門,如果你對數(shù)據(jù)庫不熟悉而基本技術(shù)又非常好持灰,九成都是會要你的盔夜,估計會先把你放到對數(shù)據(jù)庫使用不是要求非常高的部門鍛煉一下。
8堤魁、數(shù)據(jù)結(jié)構(gòu)和算法分析
數(shù)據(jù)結(jié)構(gòu)和算法分析喂链,對于一名程序員來說,會比不會好而且在工作中絕對能派上用場妥泉。數(shù)組椭微、鏈表是基礎(chǔ),棧和隊列深入一些但也不難盲链,樹挺重要的赏表,比較 重要的樹AVL樹检诗、紅黑樹,可以不了解它們的具體實現(xiàn)瓢剿,但是要知道什么是二叉查找樹逢慌、什么是平衡樹,AVL樹和紅黑樹的區(qū)別间狂。記得某次面試攻泼,某個面試官和 我聊到了數(shù)據(jù)庫的索引,他問我:
你知道索引使用的是哪種數(shù)據(jù)結(jié)構(gòu)實現(xiàn)嗎鉴象?
LZ答到用的Hash表吧忙菠,答錯。他又問纺弊,你知道為什么要使用樹嗎牛欢?LZ答到因為Hash表可能會出現(xiàn)比較多的沖突,在千萬甚至是上億級別的數(shù)據(jù)面 前淆游,會大大增加查找的時間復(fù)雜度傍睹。而樹比較穩(wěn)定,基本保證最多二三十次就能找到想要的數(shù)據(jù)犹菱,對方說不完全對拾稳,最后我們還是交流了一下這個問題,我也明白了 為什么要使用樹腊脱,這里不說访得,網(wǎng)友朋友們覺得索引為什么要使用樹來實現(xiàn)呢?
至于算法分析陕凹,不會悍抑、不想研究就算了,記得某次面試對方問我杜耙,Collections.sort方法使用的是哪種排序方法搜骡,額,吐血三升泥技。當(dāng)然為了 顯示LZ的博學(xué)浆兰,對算法分析也有一定的研究(⊙﹏⊙)b磕仅,LZ還是硬著頭皮說了一句可能是冒泡排序吧珊豹。當(dāng)然答案肯定不是,有興趣的網(wǎng)友朋友們可以去看一下 Collections.sort方法的源代碼榕订,用的是一種叫做TimSort的排序法店茶,也就是增強型的歸并排序法。
9劫恒、Java虛擬機
出乎LZ的意料贩幻,Java虛擬機應(yīng)該是很重要的一塊內(nèi)容轿腺,結(jié)果在這幾家公司中被問到的概率幾乎為0。要知道丛楚,LZ去年可是花了大量的時間去研究Java虛擬機的族壳,光周志明老師的《深入理解Java虛擬機:JVM高級特性與最佳實踐》,LZ就讀了不下五遍趣些。
言歸正傳仿荆,雖然Java虛擬機沒問到,但我覺得還是有必要研究的坏平,LZ就簡單地列一個提綱吧拢操,談?wù)凧ava虛擬機中比較重要的內(nèi)容:
(1)Java虛擬機的內(nèi)存布局
(2)GC算法及幾種垃圾收集器
(3)類加載機制,也就是雙親委派模型
(4)Java內(nèi)存模型
(5)happens-before規(guī)則
(6)volatile關(guān)鍵字使用規(guī)則
也許面試無用舶替,但在走向大牛的路上令境,不可不會。
10顾瞪、Web方面的一些問題
Java主要面向Web端舔庶,因此Web的一些問題也是必問的。LZ碰到過問得最多的兩個問題是:
談?wù)劮植际絊ession的幾種實現(xiàn)方式
常用的四種能答出來自然是讓面試官非常滿意的玲昧,另外一個常問的問題是:
講一下Session和Cookie的區(qū)別和聯(lián)系以及Session的實現(xiàn)原理
這兩個問題之外栖茉,web.xml里面的內(nèi)容是重點,F(xiàn)ilter孵延、Servlet吕漂、Listener,不說對它們的實現(xiàn)原理一清二楚吧尘应,至少能對它 們的使用知根知底惶凝。另外,一些細(xì)節(jié)的方面比如get/post的區(qū)別犬钢、forward/重定向的區(qū)別苍鲜、HTTPS的實現(xiàn)原理也都可能會被考察到。
噢玷犹,想起來了混滔,一致性Hash算法貌似也被問到了幾次,這個LZ以前專門深入研究過并且寫了兩篇博文歹颓,因此問到這個問題LZ自然是答得毫不費力坯屿。文章是MemCache超詳細(xì)解讀和對一致性Hash算法,Java代碼實現(xiàn)的深入研究巍扛,特別說明领跛,LZ真的不是在為自已以前寫的文章打廣告啊啊啊啊啊啊。
最后撤奸,如果有興趣有時間吠昭,建議學(xué)習(xí)喊括、研究一下SOA和RPC,面向服務(wù)體系矢棚,大型分布式架構(gòu)必備郑什,救命良方、包治百病蒲肋、屢試不爽蹦误。
原文地址:http://my.oschina.net/dyyweb/blog/645317