尋找卓越的(Android)軟體工程師(譯)

wutongke發表於2019-02-26

在過去五年中,我一直做Android相關的工作。在這期間,我與不同背景,不同水平的工程師進行過合作。有些工程師有非常豐富的經驗,有些是剛走出校園的應屆生,它們擁有的只是學校學習到的知識並利用業餘時間進行App的開發。還有些工程師甚至不是CS專業,僅僅是自學的。在合作過程中,我目睹了不同型別工程師的工作交付內容和方式。

所以,如果你是一個Android軟體工程師,可以嘗試讀一下這篇文章。首先,很多人誤認為移動開發非常簡單,移動應用就是把根據後端的設計把一些介面組合在一起。真的是這樣嗎,其實這與實際情況差的很遠。實際上,如果你看一下PlayStore上的應用,你就會發現app的質量分佈其實是一個高斯分佈,低質量的app很少,同時高質量的app也很少。

這裡我定義一下平庸的App是什麼

在一個非常基本的層面上, 一個平庸的app 與作業系統不能很好地相容。首先,不遵循平臺要求的 設計語言,這會使得使用者感到困惑。第二,不考慮執行環境(記憶體、cpu、頻寬、電量)實際上是有限制的。第三,在某些條件下不能工作(比如在弱網環境下)。現在的大部分軟體都存在最後一個問題。

簡而言之,以上三點就是構建一個好的移動應用的挑戰。此外,App需要與公司的基礎需求合理地整合,適應不斷變化的業務需求。

所以如果我要尋找可以處理以上三個挑戰的軟體工程師,以下幾點是我關注的:

  • 較好的軟體工程和技術水平 這包括:SOLID(物件導向設計)原則,clean code,應用架構和測試。資料結構和演算法也很重要。但是我不在意麵試者是否可以平衡二叉排序樹。我關注面試者是否理解基本的資料結構(Lists, queues, trees, hash maps),是否理解 O 是什麼,可以討論時間和空間的交換,就是最基本的技能。

  • 熟悉java語言(如果面試者非常熟悉其他的語言,我也不會拒絕)。

  • 理解併發 因為App是響應式的,所以不可以在主執行緒中執行耗時任務。很多事情需要在其他執行緒執行,如果面試者不能處理併發程式設計,他們需要在工作和專案中學習。

  • 理解分散式系統 隨著移動應用變得越來越靈敏,需要設計為可以離線使用。這意味著如果網路有故障,相同的使用者可能會面對不同的狀態。因此,面試者需要了解CAP(Consistency,Availability,Partition Tolerance theorem)理論和分散式系統的共識模型。

  • 分析解決問題的能力 面試者需要對事物的工作原理保持好奇,並且有大局觀。

  • 較好的口頭和書面表達能力 在技術上,溝通交流非常重要。面試者清晰地表達自己的想法,同時合理的文件說明是非常重要的。其實,是否擅長寫文件一定程度上也代表了程式碼能力。

  • 理解當前的技術環境和對設計與工程的影響

我並不擔心面試者是否對SDK本身理解多少。如果面試者理解以上的幾點,即使他只是一個Android的使用者,也可以快速地學習。也就是說,面試者同時擁有好的CS背景,瞭解android生態環境,還要知道以下的一些基本概念:

  • 可以畫出Android的基本架構

  • 可以描述在點選Android studio的一個按鈕之後具體發生了什麼邏輯

  • 理解基本的Dalvik和ART 虛擬機器

  • Android程式間通訊原理

  • app的沙箱機制以及為什麼要用沙箱

  • 許可權系統(許可權在底層是如果實現的)

  • 程式和應用生命週期

  • 還有一點是可以和麵試者聊他擅長的話題,如果他擅長ui,就可以和他聊UI。

可以發現重要的是判斷面試者是否知道核心的基礎和概念,從而較好地處理分給他們的任務。一定不要僱傭只會使用一兩個library的員工。工程師不僅在必要時會使用library,而且可以在提供解決問題的方法之前可以分析使用情景,預見可能的問題。

再次強調,一定不要僱傭只會使用一兩個library的工程師。

當然,我這裡描述的條件適用於senior 工程師。同樣也需要僱傭一些junior工程師。但是一定要控制好兩種工程師的比例。如果團隊中有太多初級工程師,那麼開發過程非常艱難,需要修改一個接一個的線上問題,直到可以程式碼達到維護性和測試性良好的程度。

如果你是一個Android工程師,你可以看一下以下的文章以提高自己的技術水平:

軟體工程技術
Clean Code — by Uncle Bob Martin
The Pragmatic Programmer — by Andy Hunt and Dave Thomas
Refactoring — by Martin Fowler
Head First Design Patterns — by Elisabeth Freeman, Eric Freeman, Bert Bates and Kathy Sierra
Patterns of Enterprise Application Architecture — by Martin Fowler (his blog is also worth following)

java
Effective Java, Second Edition — by Joshua Bloch

併發
Java Concurrency In Practice — by Brian Goetz

資料結構和演算法
Introduction to Algorithms (a.k.a The Cormen book) — by Charles E. Leiserson, Clifford Stein, Ronald Rivest and Thomas H. Cormen.or The Algorithm Design Manual — by Steven Skienna

計算機文化
Subscribe to ACM Queue
Love the Papers
Listen to Software Engineering Radio and/or Software Engineering Daily

問題解決技巧
How To Solve It — by G. Polya and John H. Conway

寫作技巧
On Writing Well — by William Zinsser

值得follow的一些blog
Chet Haas’s blog. Specifically These series of articles he (Chet) wrote about Android development
Dan Lew’s blog
Jake Wharton’s blog
Jesse Wilson’ blog
Cyril Mottier’s blog
Chris Bane’s and Roman Nurik’s blogs for UI related subjects.
Listen to Android Backstage and The Fragmented Podcast.
And finally do subscribe to Android Weekly, to read about the latest stuff in the Android development world.

此文為譯文,原文地址hackernoon.com/what-makes-…

歡迎關注公眾號wutongke,每天推送移動開發前沿技術文章:

尋找卓越的(Android)軟體工程師(譯)
wutongke

推薦閱讀:

重要-作為Android開發者必須瞭解的Gradle知識

編寫高效的Android程式碼(譯)

Android中使用gradient的一條建議

尋找卓越的(Android)軟體工程師

相關文章