- 浏览: 229445 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
thebye85:
引用 另外一个需要注意的问题,就是SessionMap和隐藏对 ...
WebWork深度探索之Session -
lanxiaoshuang:
写的真好
说的都是概念——有关编程范式 -
lhz:
grep unique wc你需要的只是这么几个小工具而已
努力做个Pragmatic Programmer
春节长假结束之后回到公司,我参加了有关CMMI的training。整个课程总有7个部分,涉及的内容十分广泛:从基于风险的项目管理到软件生命周期,再到项目计划和跟踪等等。而到上个星期为止,课程已经过半,而我对于CMMI有了一点点的认识,也引发了一些思考。
还是先从认识开始吧。当你第一次看到CMMI这个名词的时候,或许你会不由得想起CMM。是的,CMMI就是CMM Intergration(CMM 集成),而CMM则是Compability Maturity Model的缩写,就是众所周知的软件能力成熟度模型了。要深入了解CMMI,还是得从CMM的历史说起。1991年,卡内基梅隆大学软件工程研究院(CMU-SEI)为了评估软件企业的成熟度创造了CMM,版本为1.0。而在1992年4月,SEI举行了一个CMM的研讨会,在广泛听取了众多软件工程专家的意见之后,又于1993年推出CMM 1.1版,这也是目前世界上比较流行和通用的CMM版本。就在CMM1.1发布到SEI于2003年不再更新CMM和支持CMM这10年间,全球成千上万的软件公司纷纷以CMM马首是瞻,依照CMM制订软件开发流程,并且对CMM认证趋之若骛。那么,为什么CMM会有如此大的魅力呢?我们都知道在一个软件项目中,有三个要素:人、技术和过程。很明显,前两个要素是不稳定的,人自然是首当其冲:对于项目组来说,在一段时间内,人员可能会发生变动。再关注到某一个组员,其工作状态也会出现起伏。技术的不稳定性也是明显的,相同技术的版本变迁,不同技术的推陈出新都突显了这种不稳定性,尤其是在当今技术发展迅速的年代,技术的不稳定性则更为突出了。三个因素当中就剩下了过程,它呈现出来的稳定性使它成为项目管理者的稻草。于是乎,软件领域的目光都集中到了过程,相应的,CMM中所谓的软件能力成熟度实质上就是软件过程的成熟度了。说到这里,您是否跟我一样,心中又多了几个大大的问号呢:过程跟能力真的可以划上等号吗?将软件过程进行了良好的定义是否就意味着拥有了无坚不摧的能力呢?
在SEI的网站上,我们可以找到两个有关CMM的权威文档,其中之一就是Capability Maturity Model for Software (Version 1.1)。文档对CMM做了全面概括的介绍,自然也包含了我们所熟知的CMM五个等级的相关信息。文档中2.2节Understanding the Maturity Levels是相当有意思的,它讲述了应该如何理解Maturity Level,同时细化到了如何分别理解五个等级的定义。这一节开篇的时候提到了CMM对成熟度不同的过程做了足够抽象的定义,同时并没有限制每个组织应该采取怎样的方式去实现与某个成熟度相对应的过程。既然是如此之抽象的定义,软件公司又根据什么进行自己的过程定义呢?CMM评估组织又根据什么标准对软件公司进行能力评定呢?该文档的第三和第四章给出这两个问题的粗略答案,有兴趣的朋友可以参阅该文档。
在浏览SEI网站上有关CMM的内容时,随处可见Sunset of the Software CMM的链接。确实如前面提到的一样,CMM在SEI的眼里已经是昨日黄花了,CMMI才是SEI时下主推的标准。确实,CMM的成功经验都来源于上世纪八十年代,而在近二十年间,软件的发展又如此之神速,新标准的提出自然是大势所趋了。从字面上看,CMMI比CMM多了一个I(Integration),这是我们最容易发现的差异所在。而事实上,CMMI标准的提出也是在集成了多个CMM标准的基础上的。对于CMMI的介绍,也就不多说了,有兴趣的朋友,可以参阅What is CMMI一文。
对于CMM和CMMI这两个Key words的介绍就到这里了,大家是不是觉得很闷了呢? 是的,我写得也快疯掉了,因为我找不到源自思考的文字,数十页的文档包含着数以百计的概念、目标以及标准,即使是所谓的实践性介绍,我都找不到丝毫的感觉。也许是自己的层次没有那么high level吧,看着CMM和CMMI的介绍,我一如两年前那样迷惘。因为从这些长篇累牍的文字中,我找不到自己的角色,也找不到自己的方向,对于它们的理解,我仍然停留在 CMM = 一大堆文档的认知层面上。不过,这样的痛苦历程还是让我了解不少有关软件过程定义的知识。我知道自己从内心排斥这种把人的因素摆在一边的标准,但是我也不禁要给自己的排斥多问几个为什么,同时我也清楚只有充分理解了CMM及CMMI才能够让自己的排斥来得更加理性而有说服力,而不是停留在厌恶繁多的文档的层面上。
然而,我知道自己的排斥是有充分的理由的。根据CMM和CMMI所涵盖的范围来看,它们关注的仅仅是过程,也就是说人的因素并没有包含其中,这就意味着这两个标准的本意并非是轻视人的因素,只是没有论述而已。事实上,一个良好而规范的过程确实是必须的,一旦工作陷入无序,拥有再厉害的人物,使用再强大的技术,也是无济于事的。但是,对于过程的强调是不是有些过分了呢?而在过程的定义当中,我看到了更多的是performance和commitment,却鲜见individual。我想,一个良好的过程不应该只讨好客户和项目管理者,还要顾及奋战在第一线的开发人员的感受。在过程中增加提高开发人员能力的步骤,让开发人员在项目开发过程中逐渐成长,这不是一个很不错的想法吗?然而,在我上training的过程中,我还是无法发现这个步骤的踪影,这不免让我有些失望。
在接下来的日子里,公司会依据CMMI的规范采取更多的措施,会把开发过程制定得越来越规范,至于效果,现在还不得而知,唯有拭目以待了。总之,过程的定义与规范是重要的,但是无视个人因素的教条化定义则令人反感。
发表评论
-
在String的面前丢脸
2004-06-18 00:39 1273重返C++的世 ... -
Summary of function parameter
2004-07-14 02:33 1159对C++这位入 ... -
此Vector非彼Vector
2004-08-05 15:51 1057在学习STL的过程中,我发现了一个熟悉的面孔— ... -
模板——泛型和STL的基础
2004-08-07 01:01 1341所谓泛型,从字面上可以猜想,就是泛化的类型(型 ... -
让人头痛的Vector(提问篇)
2004-08-07 16:55 1236在写完了此Vector非彼Vector这篇随笔 ... -
我该怎样shuffle呢
2004-08-10 01:47 1214在STL的Algorithm中有着这样的一种算 ... -
WebWork初体验
2004-08-11 17:43 1315在这篇ASP.NET ... -
WebWork深度探索之盲人摸象
2004-08-12 23:54 1158昨天尝试着利用WebWork做了一个小功能[1 ... -
WebWork深度探索之号外
2004-08-14 09:03 1059昨天开始对WebWork进行了一些初步的探索[ ... -
WebWork深度探索之标签库
2004-08-15 00:28 1538由于WebWork本身提供了一套自定义的标签库 ... -
什么是Law of Demeter
2004-08-15 14:22 1248今天一如昨日,继续对WebWork进行小打小闹 ... -
所谓的Dumb Question
2004-08-15 17:16 1042为了能够更 ... -
WebWork深度探索之标签库(续)
2004-08-16 15:58 1137昨日对WebWork的标签库进行了小小的研究[ ... -
WebWork深入探索之初见端倪
2004-08-19 16:35 928使用WebWork进 ... -
建网站的小Tips
2004-08-20 23:58 1042这几天都在忙着做一个小网站,从网页美工到后台处 ... -
URL与RequestDispatcher
2004-08-21 23:58 1009今天照例继续自己的网站建设之旅,原本以为可以大 ... -
WebWork深度探索之Pitfall
2004-08-25 14:31 983在使用WebWork进行开发的过程中,她的种种 ... -
WebWork深度探索之Session
2004-08-26 15:38 1530昨天上午刚 ... -
搞笑的textarea标签
2004-08-31 18:17 1588很久没有用 ... -
两天四疑问
2004-09-03 10:56 10049月份的前两天,我仍然做着网站开发的工作。在开 ...
相关推荐
CMMI简介——关于CMM基本思想 Capability Maturity Model Integration(CMMI)是一种过程改进模型,旨在帮助组织改进软件开发和维护过程。CMMI 模型提供了一套可供公众使用的准则,描述了成功地实施过程改进的组织...
CMMI 和 CMM 的主要区别 CMMI(Capability Maturity Model Integration,能力成熟度模型集成)和 CMM(Capability Maturity Model,能力成熟度模型)都是软件过程改进的模型,但它们之间存在着一些关键的区别。 1....
CMM/CMMI,即软件能力成熟度模型集成,是一种评估和改进软件开发组织能力的框架,由美国卡内基梅隆大学软件工程研究所(SEI)开发。它旨在通过系统化的过程管理和改进,帮助组织提升软件质量和开发效率,确保项目...
软件工程简介及CMM_CMMI模型介绍,软件工程简介及CMM_CMMI模型介绍,软件工程简介及CMM_CMMI模型介绍
CMM和CMMI都是软件工程和系统工程领域的重要工具,它们提供了评估和改进组织过程成熟度的有效框架。虽然CMMI在CMM的基础上进行了扩展和深化,但选择哪种模型应基于组织的具体情况和发展需求。无论是CMM还是CMMI,其...
/CMM和CMMI的发展及应用.pdf
/CMM和CMMI的发展及应用.docx
CMM/CMMI讲座PPT,讲述了CMM1到5级的完整内容
CMM CMMI各级过程域 CMM CMMI各级过程域
主要从CMM和CMMI的要求出发,介绍了标准主要涉及的配置管理内容,并对相应内容进行初步地说明,最后提供了一个配置管理在项目实施的指南和一个在组织中部署配置管理的模型。
CMM(Capability Maturity Model,能力成熟度模型)与CMMI(Capability Maturity Model Integration,能力成熟度模型集成)是软件开发过程管理和改进的重要框架,它们为组织提供了一种评估和提升其软件开发能力的...
### CMMI 概论——CMMI简介全过程 #### CMMI的起源与发展 CMMI(Capability Maturity Model Integration,能力成熟度模型集成)起源于20世纪80年代初美国卡内基梅隆大学软件工程研究所(SEI)。当时,SEI应美国...
【CMM-CMMI实施过程】CMM(Capability Maturity Model,能力成熟度模型)和CMMI(Capability Maturity Model Integration,集成能力成熟度模型)是SEI(Software Engineering Institute,软件工程研究所)提出的软件...
### CMM、CMMI标准名词术语解析 #### 1. AT Assessment Team 评审小组 - **定义**:评审小组是一组被指定负责评估组织内软件开发或项目管理过程是否符合既定标准的专业人员。 - **作用**:通过专业的视角审查项目的...
cmmi与CMM的比较分析
北京 本文主要从CMM和CMMI的要求出发,介绍了标准主要涉及的配置管理内容,并对相应内容进行初步地说明,最后提供了一个配置管理在项目实施的指南和一个在组织中部署配置管理的模型。 1配置管理内容的逻辑关系 在...
CMMI,全称为Capability Maturity Model Integration,中文译为能力成熟度模型集成,是国际上评价软件开发和项目管理成熟度的一项重要标准。CMMI3是CMMI的第三个级别,代表“已定义级”,标志着一个组织的软件开发...
CMM(Capability Maturity Model,能力成熟度模型)与CMMI(Capability Maturity Model Integration,能力成熟度模型集成)是软件开发过程管理和改进的重要框架,尤其在IT行业中被广泛应用于提升组织的软件开发效率...
CMMI(Capability Maturity Model Integration,能力成熟度模型集成)是一种评估和改进组织在软件开发和服务过程中的能力成熟度的框架。CMMI模型旨在提高软件开发的效率、质量和可维护性,通过一系列的过程改进活动...