前言
這幾年面過的各種Android開發也有三位數了,failed的不敢說,pass的基本都沒有看走眼,來得晚了也想說說我的體會。
一般面試時間短則30分鐘,多則1個小時,這麼點時間要全面考察一個人難度很大,需要一些技巧,這裡我不侷限於回答題主的問題,而是分享一下我個人關於如何做好Android技術面試的一些經驗。
首先,面試官們一定要知道,每個人由於經歷不同,擅長的方向是千差萬別的,所以一定不會抓住自己擅長的某個方面去問的很深,覺得“如果連這個都不會還算毛程式設計師啊”。
所以在面試官問問題的時候,往往是“兩步走”的迴圈:
問他做過什麼,如果有成品的話,我能看看更好。從他做過的東西里面,找到問題進行提問。具體的問題要看情況,可以是介面或效果的實現方式、相關bug的排除、該部分原理的分析。
面試考察哪些點?1. 簡歷是否真實
這其實是面試第一要務,面試的過程其實就是看簡歷是否屬實的過程,因為能到面試環節,說明這個人是符合要求的,不滿足要求的早就被剔除了,如果他真的如簡歷描述的那樣,100%會招過來,如果人人都如此,那就不需要有面試這種過程了。
需要注意的是這裡的真實有三層含義:
一是他如實描述了自身經歷,很多人只在一些大專案裡做一個很小的螺絲釘,但簡歷裡往往誇張這段經歷。二是不知道自己不知道,常見於簡歷裡各種“精通”開頭的描述,因為知識體系與視野的侷限,明明只是瞭解很淺卻誇口精通,很多時候他並不認為自己說的有問題,而是真的以為自己已然精通,有點井底之蛙的感覺。三是簡歷裡的真實要與你的期望相匹配,一門技術瞭解到怎樣的程度才算精通,很難有定論,所以這裡的“真實”只能是候選人與面試官標準之間的契合,這種有主觀運氣成分,也許面試官水平不夠錯誤判斷了你,也不用感到不爽,面試何嘗不是種雙向選擇呢。2. 技術的深度
技術的深度一向是我最看重的部分,當今任何一個技術領域都非常寬廣,一個人要同時掌握那麼多知識並且都深入幾乎不可能,那都需要拼學習效率與工作年限了。而你曾經做過的東西,正在做的東西,是絕對可以瞭解得更深入的,一個對技術有好奇心,有技術熱情的人,都不會僅僅停留在這個東西挺好用,而是會忍不住去探究它背後的技術原理,即便不是親自去看原始碼,也會花點時間瞭解別人整理過的經驗,所以單憑考察技術上的深度,就可以考察一個人是否對技術有熱情,是否有技術好奇心等等這些很多大牛認為的所謂“優秀程式設計師的特徵”。
之前曾看到過一句話:“一個人對他所做的事情瞭解得越深,他就能做的越好”。放在這裡再合適不過了。
3. 技術的廣度
深度是有了,還需要廣度嗎?我個人的理解是:深度是必要條件,廣度是加分項。同樣的有技術好奇心的優秀程式設計師,也不會滿足於僅僅侷限於自己的一畝三分地,工作之餘,也會想要嘗試一些其它的領域和方向,因為投入問題也許不夠深入,但很多領域知識你知道與不知道,對你個人知識體系的形成關係很大。比如你要實現一個功能,在你當前熟悉的技術領域上很困難或者效果不佳,在你就要放棄時你的同事告訴你,這用一個簡單sql語句就可以實現啦,為什麼要搞得那麼麻煩?這個例子雖然舉得很蹩腳,但是我想意思大家應該已經明白了。知識越有廣度,頭腦裡的技術體系就越完備,同樣的問題,你就可以想到N個解,思考一下就得出最優解了,如果你聽都沒聽過一些東西,就會經常說出“這個好難搞啊”,“這根本就不可能”,其實有的時候真是知識的侷限問題,所謂的從0到1難,也是這個意思。
4. 邏輯思維能力
這也是我比較看重的一點,這裡並不是指那些臭名昭彰的腦經急轉彎問題,而是透過交流觀察,判斷一個人表達觀點邏輯是否清晰,回答問題是否有章法,這個很難描述,但如果你細心觀察,你會發現很容易透過一些簡單的交流,就可以看出一個人是否邏輯清晰。有時候你會覺得某個人表達溝通很不錯,其實不是溝通的問題,是他說出去的話,經過了他大腦的條理清晰的整理,讓你很容易就能明白。這種習慣不是一朝一夕就能養成的,所以面試過程中這點裝不出來。
另外一個人如果邏輯清晰,而且反應又敏捷,語速很快,那是大大的加分項,恭喜你,碰到一個聰明人了。
具體問哪些問題?前面提到的是要重點考察的點,那麼具體的Android開發,有沒有一些通用的問題可以問的呢?我個人一般會從這幾個角度考察候選人:
1. Android經驗
如果不是校招,Android經驗是必須的,我比較喜歡問一些基礎概念與技術原理,比如Activity、View、Window的理解,各LaunchMode的使用場景,View的繪製流程,Touch事件機制,Android動畫的原理,Handler, Looper的理解,Android跨程序通訊的方式,Binder的理解,Android Mashup設計的理解等等。
2. Java水平
基本上就是Effective Java那本書裡提到的東西,如果你背完那本書裡的問題,並且對答如流,沒問題,就要你這樣的。其實也會考察關於final用法,反射原理,註解原理,java編譯過程,GC等一些常見問題。
3. IT基礎知識
其實就是計算機科班學生學校裡學到的一些東西,在校招時這塊是重點,社招會放寬,但一些基本的常識是要有的,比如不少人都不知道http的get post有啥區別,https的那個s是什麼意思,講不清程序與執行緒的概念,不知道二分演算法是個啥東西。這些簡單問題的篩選,可以過濾一些所謂野路子的程式設計師,是不是科班出身不重要,搞這行就得對一些基本常識有概念,不然以後怎麼愉快的交流呢?
4. 程式碼質量的認識
我們需要的是一個對程式碼味道有感覺的人,關於這點,看下《Clean Code》就夠了,面試中這點其實不好考察,可以讓他聊一聊對程式碼質量的認識,雖然不能排除對方誇誇其談,至少想法不多,只能提到命名風格這一點的人是不符合要求的,也可以在寫Code的環節中觀察。
5. 技術視野
比如對Android開發新技術的瞭解與學習,對其它流行技術領域的瞭解,這其實與我剛才提到的技術廣度的考察有關,就我面試過程中,發現很多非網際網路行業的從業人員,因為公司各種操蛋規定與公司技術氛圍的原因,技術視野相當狹窄。
我個人對這點深有體會,2011年我還在傳統行業從事軟體研發,當時的公司因為擔心技術資訊洩露,不讓上網,相當封閉,我個人雖然自認為已在那個行業內做到業內專家的級別,但總感覺哪裡不對,有一天我很興奮的打算跟身邊同事聊一聊Android的時候,發現他們居然都不知Android為何物?2011年啊同志們,當時的震驚無法言表,深切感覺到需要作出改變了,毅然放棄多年行業積累,轉戰移動網際網路,直到現在。時至今日,多年前的小夥伴也有很多混出了名黨,開始走向人生巔峰,我也從來沒有後悔當初做出的選擇。
6. 技術想象力
一個優秀的技術人,如果知識的深度與廣度足夠,知識已成體系,那麼他對於一些從未接觸過的領域,也是可以做出足夠合理的想象與判斷,面試過程中如果問到一些領域候選人沒有涉獵,這時候一般不用過多糾纏,但如果你想借這個問題考察下他的技術想象力,可以深入下去,比如問他:“你覺得這個東西應該是什麼原理呢?”,“這個酷炫的控制元件,如果要你來做,你會怎麼實現?”。在這方面表現出色的同學無疑是有深厚基礎與足夠廣度的人。
7. 技術習慣
好的程式設計師都會有好的習慣,比如各種快捷鍵的熟練應用,各種命令列的掌握,一些提高開發效率的工具與習慣,碰到問題是baidu還是google,有沒有做一些小工具幫助減少重複工作,工作之餘有沒有繼續學習?有沒有看什麼不錯的書等等,這些小細節很大程度上決定了程式設計師的開發效率,這也是為什麼很多人說一個優秀程式設計師抵得上100個普通程式設計師,這也是重要原因之一。
什麼樣的程式設計師才給透過呢?
透過標準因人而異,每個人都有自己心中的bar, 但還是有些可直觀考量的因素的:
1.崗位的要求,不同的崗位標準當然不一樣,校招與設招肯定也不一樣。2.崗位的緊急程度,兄弟們天天加班忙死了,趕緊找人過來幫忙吧哈哈。3.候選人的年齡,大齡程式設計師莫怪,一把年紀了還跟剛畢業一兩年的同事一個水平,說明成長太慢,做技術的潛力有限,這個大家應該能理解。4.前面提到的做技術的深度,這個是必須的,廣度也要有一些,視野不能太窄。5.要有亮點,大家在面試的過程中要注意發掘亮點,有時候他問題很多但有一個足夠的亮點也夠了,用心觀察也發現不了什麼亮點的,就要注意了。
這裡給大家提供一個方向,進行體系化的學習:
1、看影片進行系統學習
前幾年的Crud經歷,讓我明白自己真的算是菜雞中的戰鬥機,也正因為Crud,導致自己技術比較零散,也不夠深入不夠系統,所以重新進行學習是很有必要的。我差的是系統知識,差的結構框架和思路,所以透過影片來學習,效果更好,也更全面。關於影片學習,個人可以推薦去B站進行學習,B站上有很多學習影片,唯一的缺點就是免費的容易過時。
另外,我自己也珍藏了好幾套影片,有需要的我也可以分享給你。
2、進行系統梳理知識,提升儲備
客戶端開發的知識點就那麼多,面試問來問去還是那麼點東西。所以面試沒有其他的訣竅,只看你對這些知識點準備的充分程度。so,出去面試時先看看自己複習到了哪個階段就好。
系統學習方向:
架構師築基必備技能:深入Java泛型+註解深入淺出+併發程式設計+資料傳輸與序列化+Java虛擬機器原理+反射與類載入+動態代理+高效IOAndroid高階UI與FrameWork原始碼:高階UI晉升+Framework核心解析+Android元件核心+資料持久化360°全方面效能調優:設計思想與程式碼質量最佳化+程式效能最佳化+開發效率最佳化解讀開源框架設計思想:熱修復設計+外掛化框架解讀+元件化框架設計+圖片載入框架+網路訪問框架設計+RXJava響應式程式設計框架設計+IOC架構設計+Android架構元件JetpackNDK模組開發:NDK基礎知識體系+底層圖片處理+音影片開發微信小程式:小程式介紹+UI開發+API操作+微信對接Hybrid 開發與Flutter:Html5專案實戰+Flutter進階知識梳理完之後,就需要進行查漏補缺,所以針對這些知識點,我手頭上也準備了不少的電子書和筆記,這些筆記將各個知識點進行了完美的總結。
3、讀原始碼,看實戰筆記,學習大神思路
“程式語言是程式設計師的表達的方式,而架構是程式設計師對世界的認知”。所以,程式設計師要想快速認知並學習架構,讀原始碼是必不可少的。閱讀原始碼,是解決問題 + 理解事物,更重要的:看到原始碼背後的想法;程式設計師說:讀萬行原始碼,行萬種實踐。
4、面試前夕,刷題衝刺
面試的前一週時間內,就可以開始刷題衝刺了。請記住,刷題的時候,技術的優先,演算法的看些基本的,比如排序等即可,而智力題,除非是校招,否則一般不怎麼會問。
關於面試刷題,我個人也準備了一套系統的面試題,幫助你舉一反三:
總結改變人生,沒有什麼捷徑可言,這條路需要自己親自去走一走,只有深入思考,不斷反思總結,保持學習的熱情,一步一步構建自己完整的知識體系,才是最終的制勝之道,也是程式設計師應該承擔的使命。