一个有意思的能力评价表:

Programmer Competency Matrix

http://www.starling-software.com/employment/programmer-competency-matrix.html

一.计算机科学(Computer Science)

数据结构(data structures

Level 0:不知道Array和LinkedList的区别

Level 1:实际编程中能解释和使用Array,LinkedList,Dictionaries等

Level 2:了解基本数据类型(Array vs LinkedList)在空间和时间上的权衡,能够解释哈希表如何实现,如何处理冲突(collisions),优先队列(Priority Queue)及如何实现等。

Level 3:了解如B-trees,二项式堆和斐波那契堆(binomial and fibonacci heaps),AVL树和红黑树(AVL/Red Black trees),伸展树(Splay Trees),跳跃表(Skip Lists),进行尝试等

算法(algorithms

Level 0:无法找到数组的平均值

Level 1:简单的排序、查找,数据结构的遍历和检索算法

Level 2:树、图、简单的贪婪和分治算法,能够理解这个矩阵水平的相关性

Level 3:能够识别和编写动态规划解决方案,良好的图算法知识,良好的数值计算算法知识,能够识别NP-问题等

系统编程(systems programming

Level 0:不知道什么是编译器,连接器或解释器

Level 1:对编译器,连接器和解释器有基本的了解,理解汇编代码及在硬件级别如何运作,一些虚拟内存和页面的知识

Level 2:理解内核模式和用户模式,多线程,同步基础,以及它们如何实现,能阅读汇编代码,理解网络如何运作,理解网络协议和socket级编程

Level 3:了解整个程序堆栈,硬件(CPU + 存储器 + 缓存 + 中断 + 微代码),二进制代码,汇编代码,静态和动态链接,编译,解释,JIT编译,垃圾回收,堆,栈,内存寻址……

二.软件工程(Software Engineering)

源代码版本控制(source code version control)

Level 0:加日期的文件夹进行备份

Level 1:VSS和初始CVS/SVN用户

Level 2:熟练使用CVS和SVN功能,知道如何分支和合并,使用补丁安装库等特性

Level 3:了解分布式VCS系统,已经试用Bzr/Mercurial/Darcs/Git

构建自动化(build automation)

Level 0:仅知道如何使用IDE进行构建

Level 1:知道如何从命令行构建系统

Level 2:能够设置脚本构建基本系统

Level 3:能够设置脚本构建系统以及文档,安装包,生成发行说明和标记源码控制的代码

自动测试(automated testing)

Level 0:认为所有测试都是测试员的工作

Level 1:已经编写自动单元测试,为正在编写的代码提出很好的单元测试用例

Level 2:按TDD(测试驱动开发)方式编写代码

Level 3:理解并能设置自动功能,负载/性能和用户界面测试(Understands and is able to setup automated functional, load/performance and UI tests)

三.编程(Programming)

问题分解(problem decomposition)

Level 0:只是使用复制粘贴的复用方式,进行直线编码

Level 1:能够将问题分成多个函数

Level 2:能够拿出可重复使用的函数/对象,解决整个问题

Level 3:使用适当的数据结构和算法,并提出了泛型/面向对象的代码封装问题的各个方面,应对问题进行变化

系统分解(systems decomposition)

Level 0:不能超过单个文件/类的级别进行思考

Level 1:在同一个平台/技术上,能分解问题空间和设计解决方案

Level 2:能够设计系统,跨越多个技术/平台

Level 3:能够可视化和设计多种产品线的复杂系统,并与外部系统集成

交流能力(communication)

Level 0:不能向同行表述思路/想法,在修辞和语法方面较差

Level 1:同行能理解你所说的话,良好的修辞和语法

Level 2:能与同行高效地沟通

Level 3:能够清楚地理解和交流思维/设计/想法/规范,在各背景下调整交流

单文件代码组织(code organization within a file)

Level 0:在文件中没有组织的迹象

Level 1:方法依逻辑和可访问性进行分组

Level 2:代码分组为不同区域,对引用的其他源代码有良好的注释

Level 3:文件有license头,摘要,良好的注释,统一的空白使用,文件看起来很美观

跨多文件代码组织(code organization across files)

Level 0:没有想过跨文件组织代码

Level 1:相关文件组织到同一文件夹中

Level 2:每个物理文件拥有唯一的用途,例如一个类的定义,一个特性的实现等

Level 3:代码组织在物理级别严密符合设计,文件名和文件夹的结构分布,能提供对设计的见解

源码树组织(source tree organization)

Level 0:所有东西放到一个文件夹中

Level 1:把代码基本分类到逻辑文件夹

Level 2:没有循环依赖,二进制文件,库,文档,构建,第三方代码都组织到适当的文件夹

Level 3:源树物理布局符合逻辑层次结构和组织,目录的名称和组织反映系统的设计见解

代码易读性(code readability)

Level 0:单音节的名字

Level 1:良好的文件名,变量名,类名,方法名等

Level 2:没有过长的函数,对特殊的代码进行注释,bug修正,代码预测(code assumptions)

Level 3:使用断言进行代码预测,代码流程自然,没有过深的条件语句和方法嵌套

防御性编程(defensive coding)

Level 0:不了解这个概念

Level 1:检查代码中所有引数(argument)并对关键预测进行断言

Level 2:确保检查返回值,检查可能失败的代码异常

Level 3:有自己的库帮助进行防御性编程,编写模拟故障的单元测试

错误处理(error handling)

Level 0:仅编写情况良好的(the happy case)代码

Level 1:围绕代码进行基本的错误处理,能够抛出异常/产生错误

Level 2:确保错误/异常以良好的方式离开程序,资源,连接和内存都被正确清理

Level 3:代码检测到可能的异常前,在代码的各个层面保持一致的异常处理策略,为整个系统提出异常处理准则

集成开发环境(IDE)

Level 0:主要采用IDE进行文本编辑

Level 1:知道它们的接口方式,能够有效地利用IDE使用菜单

Level 2:知悉最常用操作的快捷方式

Level 3:写了自定义宏

应用编程接口(API)

Level 0:需要频繁查看文档

Level 1:记住最常用的API

Level 2:广泛而深入的API知识

Level 3:在API之上编写了库,以简化常用任务,填补API的空白

框架(frameworks)

Level 0:没有使用过核心平台以外的任何框架

Level 1:听说过,但没有使用过平台流行的框架

Level 2:在专业级别上使用一个以上的框架,通晓框架的风格特色(idiom)

Level 3:框架的作者

需求(requirements)

Level 0:接受给定的需求并按照规格编程

Level 1:对规格中遗漏的方面提出质疑

Level 2:了解全貌,提出需要制定的所有领域(entire areas)

Level 3:能够基于自身经验,对给定的需求提出更好的选择和流程

脚本(scripting)

Level 0:不了解脚本工具

Level 1:批处理文件/shell脚本

Level 2:Perl/Python/Ruby/VBScript/Powershell

Level 3:已编写和发布可重用代码

数据库(database)

Level 0:认为Excel就是数据库

Level 1:了解基本的数据库概念,规范,ACID(数据库事务正确执行的四个基本要素,原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability)),事务,能编写简单的select语句

Level 2:能够设计良好和标准化的database schemas,牢记这将不得不运行,熟练使用视图,存储过程,触发器和用户自定义类型,了解聚集索引和非聚集索引的区别,熟练使用ORM(对象关系映射)工具

Level 3:能够进行基本的数据库管理,性能优化,索引优化,编写高级的select查询,能用关系sql取代游标的使用,理解内部如何存储数据,如何存储索引,理解数据库可以被镜像、复制等,理解两阶段递交是如何运作的(how the two phase commit works)

四.经验(Experience)

语言专业经验(languages with professional experience)

Level 0:指令式(Imperative)或面向对象(Object Oriented)编程

Level 1:指令式(Imperative),面向对象(Object Oriented)和宣告式(declarative)(SQL)编程,如果了解静态和动态类型、强类型和弱类型则加分

Level 2:函数式(Functional)编程,懒惰计算法(lazy evaluation),科里化(Currying is the process of transforming a function that takes multiple arguments into a function that takes just a single argument and returns another function if any arguments are still needed.),延续(Continuations)

Level 3:并行(Concurrent)(Erlang, Oz)和逻辑(Logic)(Prolog)编程

平台专业经验(platforms with professional experience)

Level 0:1

Level 1:2-3

Level 2:4-5

Level 3:6+

经验年限(years of professional experience)

Level 0:1

Level 1:2-5

Level 2:6-9

Level 3:10+

领域知识(domain knowledge)

Level 0:没有相关领域知识

Level 1:做领域中至少一种产品的工作

Level 2:做同领域中多种产品的工作

Level 3:领域专家,曾设计和实现领域中多个产品/解决方案,精通领域中使用的标准条款和协议

五.知识(Knowledge)

工具知识(tool knowledge)

Level 0:仅限于主要的IDE(VS.Net, Eclipse等)

Level 1:了解一些流行和标准工具的替代品

Level 2:掌握编辑器,调试器,IDE,开源替代品等,例如知道Scott Hanselman的power tools list中所列的绝大多数工具,使用过ORM工具

Level 3:在实际中已编写工具和脚本,如已发布则加分

语言涉及(languages exposed to)

Level 0:指令式(Imperative)或面向对象(Object Oriented)语言

Level 1:指令式(Imperative),面向对象(Object Oriented)和宣告式(declarative)(SQL)语言,如果了解静态和动态类型、强类型和弱类型则加分

Level 2:函数式(Functional)语言,懒惰计算法(lazy evaluation),科里化(Currying is the process of transforming a function that takes multiple arguments into a function that takes just a single argument and returns another function if any arguments are still needed.),延续(Continuations)

Level 3:并行(Concurrent)(Erlang, Oz)和逻辑(Logic)(Prolog)编程语言

代码库知识(codebase knowledge)

Level 0:从没看过代码库

Level 1:具有代码布局以及如何构建系统的基本知识

Level 2:良好的代码库的工作知识,实现了一些bug修正甚至一些小特性

Level 3:已实现代码库中多个的较大的特性,能够很方便地显示大部分特性和bug修正

关于即将到来技术的知识(knowledge of upcoming technologies)

Level 0:没听过即将到来的新技术

Level 1:听说到领域中即将到来的新技术

Level 2:已下载Alpha预览版本/CTP版(Community Test Preview 社区测试试用版)/beta版,阅读相关文章和用户手册

Level 3:

平台内部原理(platform internals)

Level 0:完全不懂平台内部原理

Level 1:对平台内部如何运作有基本认识

Level 2:深入理解平台内部原理,能想象平台如何处理程序并将之转换为可执行代码

Level 3:已经为平台内部编写工具以强化机能和提供信息,如反汇编器(disassemblers),反编译器(decompilers),调试器(debuggers)等

书籍(books)

Level 0:入门系列(Unleashed series),21天系列(21 days series),24小时系列(24 hour series),傻瓜系列(dummies series)

Level 1:《Code Complete(代码大全)》,《Don’t Make me Think》,《Mastering Regular Expressions(精通正则表达式)》

Level 2:《Design Patterns(设计模式)》,《Peopleware(人件)》,《Programming Pearls(编程珠玑)》,《Algorithm Design Manual(算法设计手册)》,《Pragmatic Programmer(卓有成效的程序员)》,《Mythical Man month(人月神话)》

Level 3:《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)

Level 0:听过但没时间

Level 1:阅读技术/编程/软件工程的博客,定义发表博客

Level 2:维护一个链接博客,存放已收集的一些有用的文章和工具的链接集合

Level 3:维护一个博客,与他人分享自己对于编程的见解和想法。