阿里Java工程師分享3年工作經驗的程序員應該具備的技能

每個程序員、或者說每個工作者都應該有自己的職業規劃,如果你不是富二代,不是官二代,也沒有職業規劃,希望你可以思考一下自己的將來。今天小編給大家分享的是一篇來自阿里 Java 工程師對 3 年工作經驗程序員的職業建議,希望對你有啓發。

  程序員的三個階段

  第一階段 -——三年

我認爲三年對於程序員來說是第一個門檻,這個階段將會淘汰掉一批不適合寫代碼的人。這一階段,我們走出校園,邁入社會,成爲一名程序員,正式從書本上的內容邁向真正的企業級開發。我們知道如何團隊協作、如何使用項目管理工具、項目版本如何控制、我們寫的代碼如何測試如何在線上運行等等,積累了一定的開發經驗,也對代碼有了一定深入的認識,是一個比較純粹的 Coder 的階段。

  第二階段——五年

五年又是區分程序員的第二個門檻。有些人在三年裏,除了完成工作,在空餘時間基本不會研究別的東西, 熱衷於研究各種技術實現細節、看了 N 多好書、寫一些博客、在 Github 上分享技術,這些人在五年後必然具備在技術上獨當一面的能力並且清楚自己未來的發展方向,從一個 Coder 逐步走向系統分析師或是架構師,成爲項目組中不可或缺的人物。

  第三階段——十年

十年又是另一個門檻了,轉行或是繼續做一名程序員就在這個節點上。如果在前幾年就抱定不轉行的思路並且爲之努力的話,那麼在十年的這個節點上,有些人必然成長爲一名對行業有着深入認識、對技術有着深入認識、能從零開始對一個產品進行分析的程序員,這樣的人在公司基本擔任的都是 CTO、技術專家、首席架構師等最關鍵的職位,這對於自己絕對是一件榮耀的事,當然老闆在經濟上也絕不會虧待你。

總結一下,我認爲,隨着你工作年限的增長、對生活對生命認識的深入,應當不斷思考三個問題:

  我到底適不適合當一名程序員?

  我到底應不應該一輩子以程序員爲職業?

  我對編程到底持有的是一種什麼樣的態度,是夠用就好呢還是不斷研究?

最終,明確自己的職業規劃,對自己的規劃負責併爲之努力。

  關於專業技能

一名 3 年工作經驗的 Java 程序員應該具備的技能,這可能是 Java 程序員們比較關心的內容。我這裏要說明一下,以下列舉的內容不是都要會的東西 —- 但是如果你掌握得越多,最終能得到的評價、拿到的薪水勢必也越高。

  1、基本語法

這包括 static、final、transient 等關鍵字的作用,foreach 循環的原理等等。今天面試我問你 static 關鍵字有哪些作用,如果你答出 static 修飾變量、修飾方法我會認爲你合格,答出靜態塊,我會認爲你不錯,答出靜態內部類我會認爲你很好,答出靜態導包我會對你很滿意,因爲能看出你非常熱衷研究技術。

讓我印象深刻的一次面試經歷,面試官直接問到了我 volatile 關鍵字的底層實現原理(順便插一句,面試和被面試本身就是相對的,面試官能問這個問題同時也讓面試者感覺到面試官也是一個喜愛研究技術的人,增加了面試者對公司的好感,我最終選擇的就是問了這個問題的公司),不要覺得這太吹毛求疵了 —- 越簡單的問題越能看出一個人的水平,別人對你技術的考量絕大多數都是以深度優先、廣度次之爲標準的,切記。

  2、集合

非常重要,也是必問的內容。基本上就是 List、Map、Set,問的是各種實現類的底層實現原理,實現類的優缺點。

集合要掌握的是 ArrayList、LinkedList、Hashtable、HashMap、ConcurrentHashMap、HashSet 的實現原理,能流利作答,當然能掌握 CopyOnWrite 容器和 Queue 是再好不過的了。另外多說一句,ConcurrentHashMap 的問題在面試中問得特別多,大概是因爲這個類可以衍生出非常多的問題,關於 ConcurrentHashMap,我提供三點回答或者是研究方向:

  ConcurrentHashMap 的鎖分段技術

  ConcurrentHashMap 的讀是否要加鎖,爲什麼

  ConcurrentHashMap 的迭代器是強一致性的迭代器還是弱一致性的迭代器

  3、設計模式

本來以爲蠻重要的一塊內容,結果只在阿里巴巴 B2B 事業部面試的時候被問了一次,當時問的是裝飾器模式。

當然咱們不能這麼功利,爲了面試而學習,設計模式在工作中還是非常重要、非常有用的,23 種設計模式中重點研究常用的十來種就可以了,面試中關於設計模式的問答主要是三個方向:

  你的項目中用到了哪些設計模式,如何使用

  知道常用設計模式的優缺點

  能畫出常用設計模式的 UML 圖

  4、多線程

這也是必問的一塊了。因爲三年工作經驗,所以基本上不會再問你怎麼實現多線程了,會問得深入一些比如說 Thread 和 Runnable 的區別和聯繫、多次 start 一個線程會怎麼樣、線程有哪些狀態。當然這只是最基本的,出乎意料地,幾次面試幾乎都被同時問到了一個問題,問法不盡相同,總結起來是這麼一個意思:

假如有 Thread1、Thread2、Thread3、Thread4 四條線程分別統計 C、D、E、F 四個盤的大小,所有線程都統計完畢交給 Thread5 線程去做彙總,應當如何實現?

你對這個問題是否有答案呢?不難,java.util.concurrent 下就有現成的類可以使用。

另外,線程池也是比較常問的一塊,常用的線程池有幾種?這幾種線程池之間有什麼區別和聯繫?線程池的實現原理是怎麼樣的?實際一些的,會給你一些具體的場景,讓你回答這種場景該使用什麼樣的線程池比較合適。

最後,雖然這次面試問得不多,但是多線程同步、鎖這塊也是重點。synchronized 和 ReentrantLock 的區別、synchronized 鎖普通方法和鎖靜態方法、死鎖的原理及排查方法等等…

  5、 IO

IO 分爲 File IO 和 Socket IO,File IO 基本上是不會問的,問也問不出什麼來,平時會用就好了,另外記得 File IO 都是阻塞 IO。

Socket IO 是比較重要的一塊,要搞懂的是阻塞 / 非阻塞的區別、同步 / 異步的區別,藉此理解阻塞 IO、非阻塞 IO、多路複用 IO、異步 IO 這四種 IO 模型,Socket IO 如何和這四種模型相關聯。這是基本一些的,深入一些的話,就會問 NIO 的原理、NIO 屬於哪種 IO 模型、NIO 的三大組成等等,這有些難,當時我也是研究了很久才搞懂 NIO。

提一句,NIO 並不是嚴格意義上的非阻塞 IO 而應該屬於多路複用 IO,面試回答的時候要注意這個細節,講到 NIO 會阻塞在 Selector 的 select 方法上會增加面試官對你的好感。

如果用過 Netty,可能會問一些 Netty 的東西,畢竟這個框架基本屬於當前最好的 NIO 框架了(Mina 其實也不錯,不過總體來說還是比不上 Netty 的),大多數互聯網公司也都在用 Netty。

  6、JDK 源碼

要想拿高工資,JDK 源碼不可不讀。上面的內容可能還和具體場景聯繫起來,JDK 源碼就是實打實地看你平時是不是愛鑽研了。我面試過程中被問了不少 JDK 源碼的問題,其中最刁鑽的一個問題——String 的 hashCode() 方法是怎麼實現的,幸好我平時 String 源代碼看得多,答了個大概。JDK 源碼其實沒什麼好總結的,純粹看個人,總結一下比較重要的源碼:

  List、Map、Set 實現類的源代碼

  ReentrantLock、AQS 的源代碼

  AtomicInteger 的實現原理,主要能說清楚 CAS 機制並且 AtomicInteger 是如何利用 CAS 機制實現的

  線程池的實現原理

  Object 類中的方法以及每個方法的作用

這些其實要求蠻高的,我去年一整年基本把 JDK 中重要類的源代碼研究了個遍,真的花費時間、花費精力,當然回頭看,是值得的 —- 不僅僅是爲了應付面試。

  7、 框架

老生常談,面試必問的東西。一般來說會問你一下你們項目中使用的框架,然後給你一些場景問你用框架怎麼做,比如我想要在 spring 初始化 bean 的時候做一些事情該怎麼做、想要在 bean 銷燬的時候做一些事情該怎麼做、MyBatis 中 $ 和 #的區別等等,這些都比較實際了,平時積累得好、有多學習框架的使用細節自然都不成問題。

如果上面你的問題答得好,面試官往往會深入地問一些框架的實現原理。問得最多的就是 Spring AOP 的實現原理,當然這個很簡單啦,兩句話就搞定的的事兒,即使你不會準備一下就好了。我遇到的最變態的是讓我畫一下 Spring 的 Bean 工廠實現的 UML 圖,當然面對這樣一個有深度的問題,我是絕對答不出來的……

  8、數據庫

數據庫十有八九也都會問到。一些基本的像 union 和 union all 的區別、left join、幾種索引及其區別就不談了,比較重要的就是數據庫性能的優化,如果對於數據庫的性能優化一竅不通,那麼有時間,還是建議你在面試前花一兩天專門把 SQL 基礎和 SQL 優化的內容準備一下。

不過數據庫倒是不用擔心,一家公司往往有很多部門,如果你對數據庫不熟悉而基本技術又非常好,九成都是會要你的,估計會先把你放到對數據庫使用不是要求非常高的部門鍛鍊一下。

  9、數據結構和算法分析

數據結構和算法分析,對於一名程序員來說,會比不會好而且在工作中絕對能派上用場。數組、鏈表是基礎,棧和隊列深入一些但也不難,樹挺重要的,比較重要的樹 AVL 樹、紅黑樹,可以不瞭解它們的具體實現,但是要知道什麼是二叉查找樹、什麼是平衡樹,AVL 樹和紅黑樹的區別。記得某次面試,某個面試官和我聊到了數據庫的索引,他問我:

你知道索引使用的是哪種數據結構實現嗎?

我答到用的 Hash 表吧,答錯。他又問,你知道爲什麼要使用樹嗎?我答到因爲 Hash 表可能會出現比較多的衝突,在千萬甚至是上億級別的數據面前,會大大增加查找的時間複雜度。而樹比較穩定,基本保證最多二三十次就能找到想要的數據,對方說不完全對,最後我們還是交流了一下這個問題,我也明白了爲什麼要使用樹,這裏不說,大家覺得索引爲什麼要使用樹來實現呢?

至於算法分析,不會、不想研究就算了,記得某次面試對方問我,Collections.sort 方法使用的是哪種排序方法,額,吐血三升。當然爲了顯示我的博學,對算法分析也有一定的研究,我還是硬着頭皮說了一句可能是冒泡排序吧。當然答案肯定不是,有興趣的朋友可以去看一下 Collections.sort 方法的源代碼,用的是一種叫做 TimSort 的排序法,也就是增強型的歸併排序法。

  10、 Java 虛擬機

出乎我意料,Java 虛擬機應該是很重要的一塊內容,結果在這幾家公司中被問到的概率幾乎爲 0。要知道,我去年可是花了大量的時間去研究 Java 虛擬機的,光周志明老師的《深入理解 Java 虛擬機:JVM 高級特性與最佳實踐》,就讀了不下五遍。

言歸正傳,雖然 Java 虛擬機沒問到,但我覺得還是有必要研究的,我就簡單地列一個提綱吧,談談 Java 虛擬機中比較重要的內容:

  Java 虛擬機的內存佈局

  GC 算法及幾種垃圾收集器

  類加載機制,也就是雙親委派模型

  Java 內存模型

  happens-before 規則

  volatile 關鍵字使用規則

也許面試無用,但在走向大牛的路上,不可不會。

  11、Web 方面的一些問題

Java 主要面向 Web 端,因此 Web 的一些問題也是必問的。我碰到過問得最多的兩個問題是:

  1. 談談分佈式 Session 的幾種實現方式

常用的四種能答出來自然是讓面試官非常滿意的,另外一個常問的問題是:

  2. 講一下 Session 和 Cookie 的區別和聯繫以及 Session 的實現原理

這兩個問題之外,web.xml 裏面的內容是重點,Filter、Servlet、Listener,不說對它們的實現原理一清二楚吧,至少能對它們的使用知根知底。另外,一些細節的方面比如 get/post 的區別、forward/ 重定向的區別、HTTPS 的實現原理也都可能會被考察到。

最後,如果有興趣有時間,建議學習、研究一下 SOA 和 RPC,面向服務體系,大型分佈式架構必備,救命良方、包治百病、屢試不爽。
原文鏈接http://mp.weixin.qq.com/s/6AapptJs_JTkV7t3Fa1lMQ

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