`
cloudmail
  • 浏览: 271940 次
  • 来自: 广州
社区版块
存档分类
最新评论

程序员能力矩阵

 
阅读更多

 

Programmer Competency Matrix

Note that the knowledge for each level is cumulative; being at level n implies that you also know everything from the levels lower than n.
Computer Science Software Engineering Programming Experience Knowledge
2n (Level 0) n2 (Level 1) (Level 2) log(n) (Level 3) Comments
data structures Doesn't know the difference between Array and LinkedList Able to explain and use Arrays, LinkedLists, Dictionaries etc in practical programming tasks Knows space and time tradeoffs of the basic data structures, Arrays vs LinkedLists, Able to explain how hashtables can be implemented and can handle collisions, Priority queues and ways to implement them etc. Knowledge of advanced data structures like B-trees, binomial and fibonacci heaps, AVL/Red Black trees, Splay Trees, Skip Lists, tries etc.
algorithms Unable to find the average of numbers in an array (It's hard to believe but I've interviewed such candidates) Basic sorting, searching and data structure traversal and retrieval algorithms Tree, Graph, simple greedy and divide and conquer algorithms, is able to understand the relevance of the levels of this matrix. Able to recognize and code dynamic programming solutions, good knowledge of graph algorithms, good knowledge of numerical computation algorithms, able to identify NP problems etc. Working with someone who has a good topcoder ranking would be an unbelievable piece of luck!
systems programming Doesn't know what a compiler, linker or interpreter is Basic understanding of compilers, linker and interpreters. Understands what assembly code is and how things work at the hardware level. Some knowledge of virtual memory and paging. Understands kernel mode vs. user mode, multi-threading, synchronization primitives and how they're implemented, able to read assembly code. Understands how networks work, understanding of network protocols and socket level programming. Understands the entire programming stack, hardware (CPU + Memory + Cache + Interrupts + microcode), binary code, assembly, static and dynamic linking, compilation, interpretation, JIT compilation, garbage collection, heap, stack, memory addressing...
2n (Level 0) n2 (Level 1) (Level 2) log(n) (Level 3) Comments
source code version control Folder backups by date VSS and beginning CVS/SVN user Proficient in using CVS and SVN features. Knows how to branch and merge, use patches setup repository properties etc. Knowledge of distributed VCS systems. Has tried out Bzr/Mercurial/Darcs/Git
build automation Only knows how to build from IDE Knows how to build the system from the command line Can setup a script to build the basic system Can setup a script to build the system and also documentation, installers, generate release notes and tag the code in source control
automated testing Thinks that all testing is the job of the tester Has written automated unit tests and comes up with good unit test cases for the code that is being written Has written code in TDD manner Understands and is able to setup automated functional, load/performance and UI tests
2n (Level 0) n2 (Level 1) (Level 2) log(n) (Level 3) Comments
problem decomposition Only straight line code with copy paste for reuse Able to break up problem into multiple functions Able to come up with reusable functions/objects that solve the overall problem Use of appropriate data structures and algorithms and comes up with generic/object-oriented code that encapsulate aspects of the problem that are subject to change.
systems decomposition Not able to think above the level of a single file/class Able to break up problem space and design solution as long as it is within the same platform/technology Able to design systems that span multiple technologies/platforms. Able to visualize and design complex systems with multiple product lines and integrations with external systems. Also should be able to design operations support systems like monitoring, reporting, fail overs etc.
communication Cannot express thoughts/ideas to peers. Poor spelling and grammar. Peers can understand what is being said. Good spelling and grammar. Is able to effectively communicate with peers Able to understand and communicate thoughts/design/ideas/specs in a unambiguous manner and adjusts communication as per the context 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.
code organization within a file no evidence of organization within a file Methods are grouped logically or by accessibility Code is grouped into regions and well commented with references to other source files File has license header, summary, well commented, consistent white space usage. The file should look beautiful.
2n (Level 0) n2 (Level 1) (Level 2) log(n) (Level 3) Comments
code organization across files No thought given to organizing code across files Related files are grouped into a folder Each physical file has a unique purpose, for e.g. one class definition, one feature implementation etc. Code organization at a physical level closely matches design and looking at file names and folder distribution provides insights into design
source tree organization Everything in one folder Basic separation of code into logical folders. No circular dependencies, binaries, libs, docs, builds, third-party code all organized into appropriate folders Physical layout of source tree matches logical hierarchy and organization. The directory names and organization provide insights into the design of the system. 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.
code readability Mono-syllable names Good names for files, variables classes, methods etc. No long functions, comments explaining unusual code, bug fixes, code assumptions Code assumptions are verified using asserts, code flows naturally - no deep nesting of conditionals or methods
defensive coding Doesn't understand the concept Checks all arguments and asserts critical assumptions in code Makes sure to check return values and check for exceptions around code that can fail. Has his own library to help with defensive coding, writes unit tests that simulate faults
2n (Level 0) n2 (Level 1) (Level 2) log(n) (Level 3) Comments
error handling Only codes the happy case Basic error handling around code that can throw exceptions/generate errors Ensures that error/exceptions leave program in good state, resources, connections and memory is all cleaned up properly Codes to detect possible exception before, maintain consistent exception handling strategy in all layers of code, come up with guidelines on exception handling for entire system.
IDE Mostly uses IDE for text editing Knows their way around the interface, able to effectively use the IDE using menus. Knows keyboard shortcuts for most used operations. Has written custom macros
API Needs to look up the documentation frequently Has the most frequently used APIs in memory Vast and In-depth knowledge of the API Has written libraries that sit on top of the API to simplify frequently used tasks and to fill in gaps in the API E.g. of API can be Java library, .net framework or the custom API for the application
frameworks Has not used any framework outside of the core platform Has heard about but not used the popular frameworks available for the platform. Has used more than one framework in a professional capacity and is well-versed with the idioms of the frameworks. Author of framework
2n (Level 0) n2 (Level 1) (Level 2) log(n) (Level 3) Comments
requirements Takes the given requirements and codes to spec Come up with questions regarding missed cases in the spec Understand complete picture and come up with entire areas that need to be speced Able to suggest better alternatives and flows to given requirements based on experience
scripting No knowledge of scripting tools Batch files/shell scripts Perl/Python/Ruby/VBScript/Powershell Has written and published reusable code
database Thinks that Excel is a database Knows basic database concepts, normalization, ACID, transactions and can write simple selects Able to design good and normalized database schemas keeping in mind the queries that'll have to be run, proficient in use of views, stored procedures, triggers and user defined types. Knows difference between clustered and non-clustered indexes. Proficient in use of ORM tools. Can do basic database administration, performance optimization, index optimization, write advanced select queries, able to replace cursor usage with relational sql, understands how data is stored internally, understands how indexes are stored internally, understands how databases can be mirrored, replicated etc. Understands how the two phase commit works.
2n (Level 0) n2 (Level 1) (Level 2) log(n) (Level 3) Comments
languages with professional experience Imperative or Object Oriented Imperative, Object-Oriented and declarative (SQL), added bonus if they understand static vs dynamic typing, weak vs strong typing and static inferred types Functional, added bonus if they understand lazy evaluation, currying, continuations Concurrent (Erlang, Oz) and Logic (Prolog)
platforms with professional experience 1 2-3 4-5 6+
years of professional experience 1 2-5 6-9 10+
domain knowledge No knowledge of the domain Has worked on at least one product in the domain. Has worked on multiple products in the same domain. Domain expert. Has designed and implemented several products/solutions in the domain. Well versed with standard terms, protocols used in the domain.
2n (Level 0) n2 (Level 1) (Level 2) log(n) (Level 3) Comments
tool knowledge Limited to primary IDE (VS.Net, Eclipse etc.) Knows about some alternatives to popular and standard tools. Good knowledge of editors, debuggers, IDEs, open source alternatives etc. etc. For e.g. someone who knows most of the tools from Scott Hanselman's power tools list. Has used ORM tools. Has actually written tools and scripts, added bonus if they've been published.
languages exposed to Imperative or Object Oriented Imperative, Object-Oriented and declarative (SQL), added bonus if they understand static vs dynamic typing, weak vs strong typing and static inferred types Functional, added bonus if they understand lazy evaluation, currying, continuations Concurrent (Erlang, Oz) and Logic (Prolog)
codebase knowledge Has never looked at the codebase Basic knowledge of the code layout and how to build the system Good working knowledge of code base, has implemented several bug fixes and maybe some small features. Has implemented multiple big features in the codebase and can easily visualize the changes required for most features or bug fixes.
knowledge of upcoming technologies Has not heard of the upcoming technologies Has heard of upcoming technologies in the field Has downloaded the alpha preview/CTP/beta and read some articles/manuals Has played with the previews and has actually built something with it and as a bonus shared that with everyone else
2n (Level 0) n2 (Level 1) (Level 2) log(n) (Level 3) Comments
platform internals Zero knowledge of platform internals Has basic knowledge of how the platform works internally Deep knowledge of platform internals and can visualize how the platform takes the program and converts it into executable code. Has written tools to enhance or provide information on platform internals. For e.g. disassemblers, decompilers, debuggers etc.
books Unleashed series, 21 days series, 24 hour series, dummies series... Code Complete, Don't Make me Think, Mastering Regular Expressions Design Patterns, Peopleware, Programming Pearls, Algorithm Design Manual, Pragmatic Programmer, Mythical Man month Structure and Interpretation of Computer Programs, Concepts Techniques, Models of Computer Programming, Art of Computer Programming, Database systems , by C. J Date, Thinking Forth, Little Schemer
blogs Has heard of them but never got the time. Reads tech/programming/software engineering blogs and listens to podcasts regularly. Maintains a link blog with some collection of useful articles and tools that he/she has collected Maintains a blog in which personal insights and thoughts on programming are shared
Thanks to John Haugeland for a reformatting of it that works much more nicely on the web.

转自: http://www.indiangeek.net/wp-content/uploads/Programmer%20competency%20matrix.htm?
分享到:
评论

相关推荐

    程序员能力矩阵教材.pdf

    程序员能力矩阵教材 程序员能力矩阵是衡量程序员能力的重要指标,它涵盖了计算机科学、软件工程、程序设计、交流等多个方面的知识点。以下是对程序员能力矩阵的详细解释: 计算机科学(Computer Science) * 数据...

    程序员能力矩阵Programmer competency matrix

    程序员能力矩阵 Programmer Competency Matrix 注意:每个层次的知识都是渐增的,位于层次n,也蕴涵了你需了解所有低于层次n的知识。

    程序员能力矩阵直得收藏

    程序员能力矩阵 程序员能力矩阵是衡量程序员能力的重要指标,本文档将对程序员能力矩阵的各个方面进行详细的解释和分析。 计算机科学(Computer Science) * 数据结构:数组、链表、字典、哈希表、优先队列、B-树...

    [译文]程序员能力矩阵 Programmer Competency Matrix.htm

    [译文]程序员能力矩阵 Programmer Competency Matrix.htm

    程序员能力矩阵——包括数据结构等

    ### 程序员能力矩阵解析 #### 计算机科学 (Computer Science) - **2^n (Level 0):** 对计算机科学领域的基础知识几乎一无所知。这可能意味着程序员刚开始学习编程,尚未深入理解计算机科学的基本原理。 - **n^2 ...

    程序员能力矩阵[归纳].pdf

    程序员能力矩阵[归纳].pdf

    程序员需要经常刷题吗-programmer-competency-matrix:程序员能力矩阵

    需要程序员经常刷题吗程序员能力矩阵 31 个问题,1-4 个选项。 等级范围:31-124 A. 计算机科学 1级 2 级 级别 3 4级 1. 数据结构 不知道Array和LinkedList的区别 能够在实际编程任务中解释和使用数组、链表、字典等...

    programmer-competency-checklist:程序员能力矩阵作为清单

    **程序员能力矩阵作为清单** 在IT行业中,程序员的能力与熟练度是评估其专业素养的关键因素。这份"程序员能力矩阵作为清单"旨在为开发者提供一个全面的框架,以便于自我评估和提升自己的技能。这个清单灵感来源于对...

    interactive-programmers-competency-matrix:这是 Sijin Joseph 的“程序员能力矩阵”互动版

    与 Vue 互动的“程序员能力矩阵” 这是最初由创建的“程序员能力矩阵”的交互式版本。 主要区别在于,此版本包含技能统计和推荐。 你的关卡也保存到 localStorage,所以不要害怕关闭标签并稍后回来。 屏幕截图 构建...

    程序员能力评估矩阵.pdf

    从文件《程序员能力评估矩阵.pdf》中,我们可以提取出多个与程序员能力相关的知识点,以下是对该文档中相关内容的知识点解析: ### 程序员能力评估 1. **计算机科学基础知识**:文档开头列出了计算机科学的基础...

    程序员的数学系列.pptx

    通过学习这本书,程序员可以更好地理解和应用数学知识,从而提高编程水平和解决问题的能力。 本书的精彩摘录也展示了数学在计算机科学中的重要地位和作用。学习数学可以帮助程序员更好地理解算法和数据结构,帮助...

    useful_article:有用的文章

    Code StyleGuides程序员能力矩阵VIM 进阶使用提问的智慧SOHO如何开始你的 SOHO 之旅Remote workingRemote working TipsRemote working 文章集锦我如何把薪水从 50人民币/天 提升到 100美元/小时的3远程工作资料整理...

    程序员数学3 的源代码

    通过学习《程序员数学3》中的线性代数部分,并结合配套代码,读者可以加深对线性代数的理解,掌握如何在实际编程项目中运用这些概念,从而提升解决问题的能力,特别是在涉及数据处理、机器学习和统计分析的领域。...

    程序员数据结构笔记 知识 能力 过程

    程序员在面对纷繁复杂的编程挑战时,数据结构的知识和能力是他们手中最锋利的武器。数据结构不仅是计算机科学的基石,更是程序员高效编程的保障。在深入理解数据结构的过程中,程序员需要关注知识的掌握、能力的提升...

    程序员的数学4:图论入门.pptx

    程序员在面对复杂的系统设计和算法优化时,常常需要借助数学工具来提升工作效率和解决问题的能力。图论作为数学的一个重要分支,在算法设计、网络分析、软件工程等多个领域都发挥着不可替代的作用。因此,对于程序员...

Global site tag (gtag.js) - Google Analytics