《软件项目管理》PPT课件.ppt
《《软件项目管理》PPT课件.ppt》由会员分享,可在线阅读,更多相关《《软件项目管理》PPT课件.ppt(240页珍藏版)》请在三一办公上搜索。
1、1,软件项目管理,1.1 项目管理过程1.2 软件生产率和质量的度量1.3 软件项目的估算1.4 成本效益分析1.5 软件项目组织与计划1.6 进度安排与跟踪,2,1.1 项目管理过程,软件项目管理的对象是软件工程项目。涉及的范围覆盖了整个软件工程过程。为使软件项目开发获得成功,关键问题是必须对软件项目的工作范围、可能风险、需要资源(人、硬件软件)、要实现的任务、经历的里程碑、花费工作量(成本)、进度安排等做到心中有数。软件项目管理可以提供这些信息。,3,什么是项目管理?,项目管理是指“在项目活动中运用专门的知识、技能、工具和方法,使项目能够实现或超过项目相关人员的需要和期限。”项目相关人员是
2、指参与项目和受项目影响的人,包括项目发起人、项目组、支持人员、客户、最终用户、供应商,项目对手。项目的核心知识是范围、时间、成本和质量。辅助知识是人力资源管理、风险管理和采购管理。,4,经过多年的发展,项目管理已经成为一个较为成熟的领域。美国项目管理协会为此建立了一套项目管理知识体系指南,作为了解和学习项目管理的知识框架和起点。它包括项目管理引论、9大项目管理知识领域的简要描述以及相关术语。本课程将结合软件开发项目的特点,在软件项目管理中全面应用项目管理的9大块知识领域以及全部的5个过程组启动、计划、执行、控制和收尾。,5,项目管理框架,6,项目过程与项目知识领域的关系,通常项目过程和项目的知
3、识领域的关系如下:,7,8,9,在系统开发生命周期(SDLC)过程中应用项目管理知识领域,与SDLC各阶段相关的知识领域的任务:,10,11,12,13,14,1、启动一个软件项目,在制定软件项目计划之前,必须 明确项目的目标和范围 考虑候选的解决方案 标明技术和管理上的要求有了这些信息,才能确定合理、精确的成本估算,实际可行的任务分解以及可管理的进度安排。软件人员和用户是在系统工程步骤中确定项目的目标和范围。,15,目标标明了软件项目的目的但不涉及如何去达到这些目的。范围标明了软件要实现的基本功能,并尽量以定量的方式界定这些功能。当明确了软件项目的目标和范围后,就应考虑候选的解决方案。有了方
4、案,管理人员和技术人员就能够据此选择一种“好的”方法,给出诸如交付期限、预算、个人能力、技术界面及其它许多因素所构成的限制。,16,2-1、制定计划:度量,什么是度量?IEEE 定义度量是“对一个系统、构件或过程具有的某个给定属性的一个定量测量”。进行度量工作,是为了了解产品开发的技术过程和产品本身。度量开发过程的目的是为了改进过程;度量产品的目的是为了提高产品质量。度量的作用是为有效地定量地进行管理。,17,为有效地度量,对于过程和产品,常常需要考虑:合适的度量是什么?所收集的数据如何使用?用于比较个人、过程或产品的度量是否合理?管理人员和技术人员可利用这些度量来了解软件工程过程的实际情况和
5、它所生产的产品质量。,18,2-2、制定计划:估算,在软件项目管理过程中关键的活动就是制定项目计划。在做计划时必须就需要的人力(以人月为单位)、项目持续时间(以年份或月份为单位)、成本(以元为单位)做出估算。这种估算大多是利用以前的花费做为参考而做出的。,19,如果新项目与以前的一个项目在大小上和功能上十分类似,则新项目需要工作量、开发持续时间、成本大致与那个老项目相同。假使项目背景完全生疏,只凭过去的经验做出估算可能就不够了。现在已有了许多用于软件开发的估算技术。其共同特点是:事先建立软件范围,20,以软件度量(以往的度量)为基础,以做出估算项目被分解为可单独进行估算的小块管理人员大多使用不
6、止一种估算技术,并用一种估算技术做为另一种估算技术的交叉检查。,21,2-3、制定计划:风险分析,每当新建一个程序时,总是存在某些 不确定性。用户要求是否能确切地被理解?在项目最后结束之前要求实现的功能能否建立?是否存在目前仍未发现的技术难题?在项目出现严重误期时是否会发生一些变更?等等。,22,风险分析对于软件项目管理是决定性的,然而现在还有许多项目不考虑风险就着手进行。所谓风险分析实际上就是一系列风险管理步骤,其中包括风险识别、风险估计、风险管理策略、风险解决和风险监督。这些步骤贯穿在软件工程过程中。,23,2-4、制定计划:进度安排,每个软件项目都要求制定一个进度安排,但不是所有进度都得
7、一样安排。对于进度安排,需要考虑的是:预先对进度如何计划?工作怎样就位?如何识别定义好的任务?管理人员对结束时间如何掌握?如何识别和监控关键路径以确保结束?,24,对进展如何度量?如何建立分隔任务的里程碑。软件项目的进度安排与任一个工程项目的进度安排基本相同。识别一组项目任务 建立任务之间的相互关联 估算各个任务的工作量 分配人力和其它资源 制定进度时序,25,3、追踪和控制,一旦建立了开发进度安排,就可以开始着手追踪和控制活动。由项目管理人员负责追踪在进度安排中标明的每一个任务。如果任务实际完成日期滞后于进度安排,则管理人员可以使用一种自动的项目进度安排工具来确定在项目的中间里程碑上进度误期
8、所造成的影响。,26,可对资源重新定向对任务重新安排(做为最坏的结果)可以修改交付日期以调整已经暴露的问题。用这种方式可以较好地控制软件的开发。,27,1.2 软件生产率和质量的度量,生产率与质量的度量是以投入工作量为依据的软件开发活动的度量和开发成果质量的度量。为什么要对软件进行度量1.2.2 面向规模的度量 面向功能的度量 软件质量的度量 在软件工程过程中使用度量,28,1.2.1 为什么要对软件进行度量,表明软件产品的质量;弄清软件开发人员的生产率;给出使用了新的软件工程方法和工具所得到的(在生产率和质量两方面)的效益;建立项目估算的“基线”;帮助调整对新的工具和附加培训的要求;在项目中
9、辅助决策。,29,度量的方式,在物理世界中的度量有两种方式。直接度量(如度量一个螺栓的长度);间接度量(如用次品率来度量生产出的螺栓质量)。软件度量也同样分为两类:直接度量与间接度量。软件工程过程的直接度量包括所投入的成本和工作量。,30,软件产品的直接度量包括产生的代码行数(LOC)、执行速度、存储量大小、在某种时间周期中报告的差错数。软件产品的间接度量包括功能性、复杂性、效率、可靠性、可维护性和许多其它的质量特性。只要事先建立特定的度量规程,很容易做到直接度量软件所需要的成本和工作量、产生的代码行数等。,31,软件的功能性、效率、可维护性等质量特性却很难用直接度量判明,只有通过间接度量才能
10、推断。,32,软件度量领域的分类,33,软件生产率度量的焦点集中在软件工程过程的输出;软件质量度量则指明了软件适应明确和不明确的用户要求到什么程度;技术度量的焦点则集中在软件的某些特性(如逻辑复杂性、模块化程度)上而不是软件开发的全过程。,34,另一种分类方法,面向规模的的度量用于收集与直接度量有关的软件工程输出的信息和质量信息。面向功能的度量提供直接度量的尺度。面向人的度量则收集有关人们开发计算机软件所用方式的信息和人们理解有关工具和方法的效率的信息。,35,1.2.2 面向规模的度量,面向规模的度量是对软件和软件开发过程的直接度量。可以建立一个面向规模的数据表格来记录项目的某些信息。该表格
11、列出了在过去几年完成的每一个软件开发项目和关于这些项目的相应面向规模的数据。,36,面向规模的数据表格,37,项目aaa-01 规模为 114.1 KLOC(千代码行)工作量用了 24个人月 成本为168,000元 文档页数为365 在交付用户使用后第一年内发现了 29个错误,有 3 个人参加了项目 aaa-01 的软件开发工作。,38,需要注意的是,在表格中记载的工作量和成本是整个软件工程的活动(分析、设计、编码和测试),而不仅仅是编码活动。对于每一个项目,可以根据表格中列出的基本数据计算简单的面向规模的生产率和质量的度量。,39,根据数据表格可以对所有的项目计算出平均值:生产率 KLOCP
12、M(人月)质量 错误数KLOC 成本 元LOC 文档 文档页数KLOC,40,1.2.3 面向功能的度量,面向功能的软件度量是对软件和软件开发过程的间接度量。面向功能度量主要考虑程序的“功能性”和“实用性”,而不是对 LOC计数。该度量是一种叫做功能点方法的生产率度量法,利用软件信息域中的一些计数和软件复杂性估计的经验关系式而导出功能点 FP。,41,面向功能的数据表格,42,功能点计算,确定五个信息域的特征,并在表格中相应位置给出计数。用户输入数:各个用户输入是面向不同应用的输入数据。用户输出数:各个用户输出是面向应用的输出信息,包括报告,屏幕信息,错误信息等。,43,用户查询数:查询是一种
13、联机的交互操作,每次询问/响应都应计数。文件数:每一个逻辑文件都应计数。逻辑文件可以是一个大数据库的一部分,可以是一个单独的文件。外部接口数:与系统中其他设备通过外部接口读写信息次数均应计数。一旦收集到上述数据,就可以计算出与每一个计数相关的复杂性值。,44,一个信息域是简单的、平均的还是复杂的,由使用功能点方法的机构自行确定,从而计算出加权计数。计算功能点,使用如下的关系式:FP 总计数(0.650.01SUM(Fi)总计数是所有加权计数项的和;SUM(Fi)是求和函数:Fi(i1.14)是复杂性校正值,它们应通过逐一回答如下提问来确定。,45,复杂性校正值 Fi的取值0.5:=0 没有影响
14、=1 偶然的=2 适中的=3 普通的=4 重要的=5 极重要的F1 系统是否需要可靠的备份和恢复?F2 系统是否需要数据通信?F3 系统是否有分布处理的功能?F4 在系统中是否性能成为关键要素?F5 系统是否运行在高度实用化的操作环境中?,46,F6 系统是否需要联机数据输入?F7 联机数据输入是否需要建立多重窗口?F8 主文件是否可以在线更新?F9 输入、输出、文件、查询界面是否复 杂?F10 内部处理过程是否复杂?F11 程序代码是否可复用?F12 设计中是否包括了转移和安装?F13 系统是否设计成可以重复安装在不同 站点中?,47,F14 系统是否设计成易修改和易使用?一旦计算出功能点,
15、就可仿照LOC的方式度量软件的生产率、质量和其它属性:生产率 FPPM(人月)质量 错误数FP 成本 元FP 文档 文档页数FP,48,功能点度量是为了商用信息系统应用而设计的。特征点度量(Feature Points)可以用于系统和工程软件应用特征点度量适合于算法复杂性高的应用。而实时处理、过程控制、嵌入式软件应用的算法复杂性都偏高,因此适合于特征点度量。,49,为了计算特征点,可以象功能点计算那样,对信息域值进行计数和加权。此外,特征点度量要对一个新的软件特征“算法”进行计数。计算特征点可使用一个计算表格。对于每一个度量参数只使用一个权值,并且使用 FP总计数(0.650.01SUM(Fi
16、)来计算总的特征点值。,50,特征点度量计算表格,51,1.2.4 软件质量的度量,质量度量贯穿于软件工程的全过程中以及软件交付用户使用之后。在软件交付之前得到的度量可作为判断设计和测试质量好坏的依据。这一类度量包括程序复杂性、有效的模块性和总的程序规模。在软件交付之后的度量则把注意力集中于还未发现的差错数和系统的可维护性方面。,52,使用得最广泛软件质量的事后度量包括正确性、可维护性、完整性和可使用性。正确性:一个程序必须正确地运行,并为它的用户提供某些输出。正确性要求软件执行所要求的功能。正确性的度量是每千代码行(KLOC)的差错数,其中将差错定义为已被证实是不符合需求的缺陷。,53,可维
17、护性:软件维护比其它的软件工程活动需要更多的工作量。还没有一种方法可以直接度量可维护性,必须采取间接度量。一种简单的面向时间的度量:平均变 更等待时间MTTC。这个时间包括分析变更要求、设计适当修改、实现变更并测试、把变更发送给所有用户。一个可维护的程序与不可维护的程序相比,应有较低的MTTC。,54,完整性:完整性度量一个系统抗拒对它的安全性攻击(事故的和人为的)的能力。软件的所有三个成分程序、数据和文档都会遭到攻击。度量完整性,需要定义两个附加的属性:危险性和安全性。危险性是特定类型的攻击将在一给定时间内发生的概率,安全性是排除特定类型攻击的概率。,55,一个系统的完整性可定义为 完整性(
18、1危险性)(1安全性)其中,对每一个攻击的危险性和安全性都进行累加。可使用性:如果一个程序不具有“用户友好性”,即使它所执行的功能很有价值,也常常会失败。可使用性量化“用户友好性”,并依据以下四个特征进行度量:,56,为学习系统所需要的体力上的和智力上的技能;为达到适度有效使用系统所需要的时间;当软件被某些人适度有效地使用时所度量的在生产率方面的净增值;用户角度对系统的主观评价(可以通过问题调查表得到)。,57,协调不同的度量方法,代码行数和功能点之间的关系依赖于用来实现软件的程序设计语言和设计质量。下面给出使用各种程序设计语言建立一个功能点所需要的平均代码行数的粗略估算。,58,建立一个功能
19、点所需平均代码行数,59,影响软件生产率的重要因素,人的因素:软件开发组织的规模和专长;问题因素:问题的复杂性和对设计限制,以及需求的变更次数;过程因素:使用的分析与设计技术、语言和CASE工具的有效性,及评审技术;产品因素:计算机系统的可靠性和性能;资源因素:CASE工具、硬件和软件资源的有效性。,60,1.2.5 在软件工程过程中使用度量,建立基线 为了将LOC和FP用于软件估算技术中,必须建立历史数据基线。根据历史经验,在软件工程过程的衔接处划出一条基线,在此基线上附有一些用于度量的经验目标信息,作为工程过程评估的依据,判断工程过程的完成是否达到预想的要求。,61,质量度量数据一旦收集到
20、,软件开发组织就可以根据它们来调整其软件工程项目,以消除那些对软件开发有重大影响的差错产生的根源。大多数软件开发人员都希望了解:哪些用户需求可能会变更?系统中哪些模块容易出错?对每一个模块要做多少测试?在测试时能够预计多少错误?,62,如果能收集到相关的度量数据,就能确定这些问题的答案。为了帮助计划、成本和工作量估算,基线的数据应当具有下列属性:数据必须合理、精确,应避免单纯根据以往项目进行“盲目估算”;应从尽可能多的项目中收集数据;数据必须一致;基线数据的应用必须与要做估算的工作类似。,63,1.3 软件项目的估算,软件项目管理过程开始于项目计划。在做项目计划时,第一项活动就是估算。在做估算
21、时往往存在某些不确定性,使得软件项目管理人员无法正常进行管理而导致产品迟迟不能完成。现在已使用的实用技术是时间和工作量估算。,64,1.3.1 估算对风险的影响,低风险区,项目复杂性,项目结构化、规约的不确定程度,项目工作量大小,65,项目复杂性对于增加软件计划的不确定性影响很大。复杂性越高,估算的风险就越高。项目规模对于软件估算的精确性和功效影响也比较大。随着软件规模的扩大,问题分解会更加困难。项目的规模越大,开发工作量越大,估算的风险越高。项目的结构化程度也影响项目估算的风险。随着结构化程度的提高,进行精确估算的能力就能提高,而风险将减少。,66,历史信息的有效性也影响估算的风险。对以往项
22、目进行综合度量,可借用来比较准确地进行估算,安排进度以避免重走过去的弯路,而总的风险也减少了。如果对软件项目的作用范围还不十分清楚,或者用户的要求经常变更,都会导致对软件项目所需资源、成本、进度的估算频频变动,增加估算的风险。计划人员应当要求在软件的规格说明中给出完备的功能、性能、接口的定义。,67,1.3.2 软件成本和工作量的估算技术,软件成本和工作量的估算中变化的东西太多,人、技术、环境、政治,都会影响软件最终成本和工作量。软件项目的估算能够通过一系列系统化的步骤,在可接受的风险范围内提供估算结果。成本估算必须“事前”给出。时间越久,了解得越多,估算中出现的严重误差就越少。,68,分解技
23、术,当一个待解决的问题过于复杂时,我们可以把它进一步分解,直到分解后的子问题变得容易解决为止。然后,分别解决每一个子问题,并将这些子问题的解答综合起来,从而得到原问题的解答。,69,LOC和FP估算,在软件项目估算中,在两个方面使用了LOC和FP数据:把LOC和FP数据当做一个估算变量,用于量度软件每一个元素的规模。LOC和FP数据作为从过去项目中收集到的基线数据,与其它估算变量联合使用,进行成本和工作量的估算。,70,LOC和FP的共性在于:给出一个有界的软件范围的叙述 由此叙述把软件分解成一些小的可分别独立进行估算的子功能 对每一个子功能估算LOC或FP 把基线生产率度量(如LOCPM或F
24、PPM)用做特定的估算变量,导出子功能的成本或工作量综合子功能的估算得到整个项目的总估算。,71,用 LOC 做为估算变量时,必须进行功能分解,且需要达到很详细的程度。而估算 FP 时需要的数据是宏观的量,当把 FP 当做估算变量时不需分解得很详细。LOC 是直接估算的,而 FP 是通过估计输入、输出、数据文件、查询和外部接口的数目,以及 14 种复杂性校正值间接地确定的。,72,项目计划人员可对每一个分解的功能提出一个有代表性的估算值范围。利用历史数据或凭实际经验(当其它的方法失效时),对每个功能分别按最佳的、可能的、悲观的三种情况给出LOC或FP估计值。记作a、m、b。接着计算LOC或FP
25、的期望值 E。E(a4mb)6,73,所有子功能的总估算变量值除以相应于该估算变量的平均生产率度量得到项目的总工作量。例如,若假定总的FP估算值是310,基于过去项目的平均FP生产率是5.5FPPM,则项目的总工作量是:工作量 3105.5 56 PM作为LOC和FP估算的实例,考察一 个为CAD应用而开发的软件包。,74,系统定义评审指明,软件是在一个工作站上运行,其接口必须使用各种计算机图形设备,包括鼠标器、数字化仪、高分辩率彩色显示器和激光打印机。在这个实例中,使用LOC做为估算变量。根据系统规格说明,软件范围的初步叙述如下“软件将从操作员那里接收2 维或 3 维几何数据。操作员通过用户
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 软件项目管理 软件 项目 管理 PPT 课件
链接地址:https://www.31ppt.com/p-4861823.html