从概念上讲,软件项目管理是为了使软件项目能够按照预定的成本、进度、质量顺利完成,而对成本、人员、进度、质量、风险等进行分析和管理的活动。实际上,软件项目管理的意义不仅仅如此,进行软件项目管理有利于将开发人员的个人开发能力转化成企业的开发能力,企业的软件开发能力越高,表明这个企业的软件生产越趋向于成熟,企业越能够稳定发展(即减小开发风险)。同时,随着软件开发规模及开发队伍的逐渐增大,软件开发不再是向过去那样一二个开发人员即可解决的事情。迫切需要一种开发规范来规范每个开发人员、测试人员与支持人员的工作,每个项目组成员按约定的规则准时完成自己的工作。同时采用规范化管理,专业分工也可以降低对开发人员的要求,从而降低产品研发成本。
软件因其复杂性和难以度量,使软件项目管理较之其他项目管理而言有其特殊性。那么何确保软件项目的质量?软件研发项目管理又应该遵循什么标准呢?软件是十分复杂且难以度量,因此对软件研发项目进行管理必须依据一定的标准。软件行业以前倡导的标准是iso9000系列,而现在更多的场合大力倡导cmm,即能力成熟度模型(capabilitymaturity model)以及psp和tsp。iso9000是国际标准化组织提出的系列标准,其中iso9003是专门为软件行业定制的。而cmm则是美国卡纳基梅隆大学软件工程研究所(cmu/sei)提出的软件研发项目管理的一系列方法。iso9000和cmm的共同点是二者都强调了软件产品的质量。所不同的是,iso9000强调的是衡量的准则,例如应该做什么、什么算好、什么算不好,却没有告诉软件开发人员如何达到好的目标,如何避免差错。cmm则提供了一整套较为完善的软件研发项目管理的方法。cmm框架可用5个不断进化的层次来表达:其中初始层是混沌的过程,可重复层是经过训练的软件过程,定义层是标准一致的软件过程,管理层是可预测的软件过程,优化层是能持续改善的软件过程。cmm并未提供有关子过程实现域所需要的具体知识和技能。因此,psp(personal software process,个体软件过程)应运而生。psp可以说是由定向软件工程走向定量软件工程的一个标志。psp为基于个体和小型群组软件过程的优化提供了具体而有效的途径,例如如何制订计划,如何控制质量,如何与其他人相互协作等等。在软件设计阶段,psp的着眼点在于软件缺陷的预防,其具体办法是强化设计结束准则,而不是设计方法的选择。psp保障软件产品质量的一个重要途径是提高设计质量。cmm/sei又在此基础上又发展出了tsp(team software process,群组软件过程)的方法。tsp指导项目组中的成员如何有效地规划和管理所面临的项目开发任务,并且告诉管理人员如何指导软件开发队伍。始终以最佳状态来完成工作。tsp实施集体管理与自己管理自己相结合的原则,最终目的在于指导开发人员如何在最少的时间内,以预定的费用生产出高质量的软件产品,所采用的方法是对群组开发过程的定义、度量和改进。单纯实施cmm,永远不能真正做到能力成熟度的升级,只有将实施cmm与实施psp和tsp有机地结合起来,才能发挥最大的效力。
目前软件开发的规模越来越大,不管你使用什么先进的软件开发技术都必须有严格的管理过程,要有效的开发出软件产品必须要有符合企业自己的软件管理过程。我们应该基本遵循怎样一个管理过程呢?一般企业项目管理过程:
1. 项目启动 :需求分析、项目选择、方案筛选、可行性分析、项目可行性分析的内容
2. 项目计划:项目计划的作用、项目计划的内容、项目计划的步骤、有效计划的建议、项目 计划的批准、改变计划。