【譯文】程式設計師能力矩陣 Programmer Competency Matrix

楊奇龍發表於2012-01-08
注意:每個層次的知識都是漸增的,位於層次n,也蘊涵了你需瞭解所有低於層次n的知識。【】
電腦科學 Computer Science
 2n (Level 0)n2 (Level 1)(Level 2)log(n) (Level 3)Comments
資料結構不知道陣列和連結串列的差異能夠解釋和使用陣列,連結串列,字典等,並且能夠用於實際的程式設計任務。瞭解基本資料結構時間和空間的折中,比如陣列vs 連結串列,能夠解釋如何實現雜湊表和處理衝突,瞭解優先佇列及其實現。高等的資料結構的知識,比如B-樹、二項堆、斐波那契堆、AVL樹、紅黑樹、伸展樹、跳躍表以及字首樹等。
演算法不能夠找出一個陣列各數的平均值(這令人難以置信,但是我的確在應聘者中遇到過)基本的排序,搜尋和資料的遍歷和檢索演算法。樹,圖,簡單的貪婪演算法和分而治之演算法,能夠適度瞭解矩陣該層的含義。能夠辨識和編寫動態規劃方案,良好的圖演算法知識,良好的數值估算的知識,能夠辨別NP問題等。Working with someone who has a good topcoder ranking would be an unbelievable piece of luck!
程式設計體系不知道何為編譯器、連結器和直譯器。對編譯器、連結器、直譯器有基本的瞭解。知道什麼是彙編程式碼以及在硬體層如何工作。有一些虛擬記憶體和分頁知識。瞭解核心模式vs使用者模式,多執行緒,同步原語以及它們如何實現,能夠閱讀彙編程式碼。瞭解網路如何工作,瞭解網路協議和socket級別程式設計。瞭解整個程式堆疊、硬體(CPU+記憶體+中斷+微碼)、二進位制程式碼、彙編、靜態和動態連結、編碼、解釋、JIT(just-in-time)編譯、記憶體碎片回收、堆、棧、儲存器編址…
軟體工程 Software Engineering
 2n (Level 0)n2 (Level 1)(Level 2)log(n) (Level 3)Comments
原始碼版本控制透過日期備份資料夾VSS和初級的CVS/SVN使用者熟練地使用CVS和SVN特性。知道如何分支和歸併,使用程式庫補丁安裝特性等有分散式VCS系統的知識。嘗試過Bzr/Mercurial/Darcs/Git
自動化編譯只知道在IDE下編譯知道如何編譯在命令列下編譯系統能夠安裝一個指令碼構建基本的系統能夠安裝一個指令碼來構建系統並且歸檔,安裝程式,生成釋出記錄和給原始碼控制中的程式碼分配標籤。
自動化測試認為所有的測試都是測試員的工作。能夠編寫自動化的單元測試,能夠為正在編寫的程式碼提出良好的測試用例。按照TDD (Test Driven Development)方式編寫程式碼。瞭解並且能夠有效自動化安裝,載入/效能和UI測試
程式設計 Programming
 2n (Level 0)n2 (Level 1)(Level 2)log(n) (Level 3)Comments
問題分解只有直線式的程式碼,透過複製貼上來複用能夠把問題分散到多個函式中能夠想出可複用的函式/物件來解決大題的問題使用適宜的資料結構和演算法,寫出通用的/物件導向的程式碼來封裝問題的易改變的層面。
系統分解N想不出比單一的檔案/類更好的層面如果不在同一平臺或沒采用相同的技術,能夠把問題空間和設計方案分解。能夠設計跨技術/平臺的系統。能夠在多個產品線和與外部體系一體化中虛擬化和設計複製的系統。同時也能夠設計支援系統監視、報告、故障恢復等。
交流不能向同伴表達想法/主意。匱乏拼寫和語法的能力。同伴能瞭解你在說什麼。有良好的拼寫和語法能力。能夠和同伴進行高效的交流能夠使用清晰的方式瞭解和交流想法/設計/主意/細則,能適應每種環境的交流This is an often under rated but very critical criteria for judging a programmer. With the increase in outsourcing of programming tasks to places where English is not the native tongue this issue has become more prominent. I know of several projects that failed because the programmers could not understand what the intent of the communication was.
同一檔案中程式碼組織同一檔案中組織沒有依據按照邏輯性或者易接近的方法程式碼分塊和對於其他原始檔來說是易於是釋,引用其他原始檔時有良好的註釋文件頭部有許可宣告,總結,良好的註釋,一致的空格縮排。文件外觀美觀。
 2n (Level 0)n2 (Level 1)(Level 2)log(n) (Level 3)Comments
跨檔案程式碼組織沒夠想過給程式碼跨檔案組織相關檔案按資料夾分組每個物理檔案都有獨立的目的,比如一個類的定義,一個特性的實現等。程式碼在物理層組織緊密,在檔名上與設計和外觀相匹配,可以透過檔案分佈方式洞察設計理念。
原始碼樹組織一切都放在一個資料夾內初步地將程式碼分散進對應邏輯的資料夾。沒有迴圈依賴,二進位制檔案,庫,文件,構建,第三方的程式碼都組織進合適的資料夾內。原始碼樹的物理佈局與邏輯層次、組織方式相匹配。可以透過目錄名稱和組織方式洞察設計理念。The difference between this and the previous item is in the scale of organization, source tree organization relates to the entire set of artifacts that define the system.
程式碼可讀性單音節的名稱 (在國內應該是那些類似用漢語拼音命名的習慣)對檔案、變數、類、方法等,有良好的命名。沒有長函式、註釋解釋不常規的程式碼,bug修復,程式碼假設。程式碼假設驗證使用斷言,自然的程式碼流,沒有深層巢狀的條件和方法
防禦性編碼不知道這個概念檢查程式碼中所有的引數,對關鍵的假設進行斷言確保檢查了返回值和使程式碼失敗的異常。有自己的庫來幫助防禦性程式設計、編寫單元測試模擬故障
 2n (Level 0)n2 (Level 1)(Level 2)log(n) (Level 3)Comments
錯誤處理只給樂觀的情形編碼基本的程式碼錯誤處理,丟擲異常/生成錯誤確保錯誤/異常留在程式中有良好的狀態,資源,連線,記憶體都有被合適的清理。在編碼之前察覺可能出現的異常,在程式碼的所有層次中維持一致性的異常處理策略,提出整個系統的錯誤處理準則。
IDEIDE大部分用來進行文字編輯瞭解其周圍的介面,能夠高效地透過選單來使用IDE瞭解最常操作的鍵盤快捷鍵編寫自定義宏
API需要頻繁地查閱文件把最頻繁使用的API記在腦子裡廣闊且深入的API知識。為了使實際任務中常用API使用更加便捷,編寫過API的上層庫,填補API之間的缺口。E.g. of API can be Java library, .net framework or the custom API for the application
框架沒有使用過主平臺外的任何框架聽過但沒用過平臺下流行的可用框架在專業的職位中使用過一個以上的框架,通曉各框架的特色。某框架的作者
 2n (Level 0)n2 (Level 1)(Level 2)log(n) (Level 3)Comments
需求分析接受給定的需求和程式碼規格能對規格的遺漏提出疑問瞭解全面情況,提出需要被規格化的整體範圍。能夠提出更好的可選方案,根據經驗的浮現給出需求
指令碼不具備指令碼工具的知識批處理檔案/shell指令碼Perl/Python/Ruby/VBScript/Powershell寫過並且發表過可重用的程式碼
資料庫認為Excel就是資料庫知道基本的資料庫概念,規範化、ACID(原子性Atomicity、一致性Consistency、隔離性Isolation、永續性Durability)、事務化,能夠寫簡單的select語句能夠牢記在執行時必要查詢中設計良好的規範化資料庫模式, 精通使用者檢視,儲存過程,觸發器和使用者定義型別。知道聚集與非聚集索引之間的差異。精通使用ORM(Object Relational Mapping物件關係對映)工具能做基本的資料庫管理,效能最佳化,索引最佳化,編寫高階的select查詢,能夠使用相關sql來替換遊標,理解資料內部的儲存,瞭解如何映象、複製資料庫。知道兩段資料提交如何工作
經驗 Experience
 2n (Level 0)n2 (Level 1)(Level 2)log(n) (Level 3)Comments
專業語言經驗命令式語言和麵向物件語言命令式語言,面嚮物件語言和說明型語言(SQL),如果瞭解靜態型別vs動態型別,弱型別vs強型別則有加分函式式語言,如果瞭解延緩求值,區域性套用函式,延續則有加分併發語言(Erlang, Oz) 邏輯語言(Prolog)
專業平臺經驗12-34-56+
專業經驗年齡12-56-910+
領域知識沒有該領域的知識在該領域中曾經至少為一個產品工作過在同一領域中為多個產品工作過領域專家。在該領域設計和實現數種產品/方案。精通該領域使用的標準條款和協議
學識 Knowledge
 2n (Level 0)n2 (Level 1)(Level 2)log(n) (Level 3)Comments
工具知識僅限於主要的IDE(VS.Net, Eclipse等)知道一些流行和標準工具的備選方案對編輯器、偵錯程式、IDE、開源的備選方案有很好的瞭解。比如某人瞭解大多數Scott Hanselman的威力工具列表中的工具,使用過ORM工具。實際地編寫過工具和指令碼,如果這些被髮布則有加分
語言接觸命令式語言和麵向物件語言命令式語言、面嚮物件語言和說明型語言(SQL),如果瞭解靜態型別vs動態型別、弱型別vs強型別則有加分函式式語言,如果瞭解延緩求值、區域性套用函式、continuations (源於scheme中的一種高階控制結構)則有加分併發語言(Erlang, Oz) 邏輯語言(Prolog)
程式碼庫知識從來沒有查詢過程式碼庫基本的程式碼層知識,瞭解如果構建系統良好的程式碼庫工作知識,實現過幾次bug修復或者完成了一些細小的特性實現了程式碼庫中多個大型特性,能夠輕鬆地將多數特性的需求變更具體化,從容地處理bug修復。
下一代技術知識從來沒聽說過即將到來的技術聽說過某領域即將到來的技術下載過alpha preview/CTP/beta版本,並且讀過一些文章和手冊試用過預覽版而且實際地構建過某物,如果共享給其他人的話則有加分
 2n (Level 0)n2 (Level 1)(Level 2)log(n) (Level 3)Comments
平臺內部對平臺內部毫無所知有平臺基本的內部工作的知識深度的平臺內部知識,能夠設想平臺如何將程式轉換成可執行程式碼。編寫過增強平臺或者為其平臺內部提供資訊的工具。比如,反彙編工具,反編譯工具,除錯工具等。
書籍菜鳥系列,21天系列,24小時系列,蠢貨系列...《程式碼大全》,《別讓我思考》, 《精通正規表示式》《設計模式》,《人件》,《程式碼珠璣》,《演算法設計手冊》,《程式設計師修煉之道》,《人月神話》《計算機程式設計與解釋》,《事務處理:概念與技術》,《計算機程式設計模型》,《計算機程式設計藝術》,《資料庫系統導論》 C.J Date版,《Thinking Forth》 ,《Little Schemer》(沒找到其中譯本)
部落格聽過但是從來抽不出空去接觸閱讀一些科技/程式設計/軟體工程的部落格,並且經常的收聽一些播客維護一些部落格的連結,收集博主分享的有用的文章和工具維護一個在程式設計方面,分享有個人見解和思考的部落格

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/22664653/viewspace-714581/,如需轉載,請註明出處,否則將追究法律責任。

相關文章