第八章 系统开发中的项目管理.ppt

上传人:Iclinic170 文档编号:388857 上传时间:2018-10-12 格式:PPT 页数:43 大小:254KB
下载 相关 举报
第八章 系统开发中的项目管理.ppt_第1页
第1页 / 共43页
第八章 系统开发中的项目管理.ppt_第2页
第2页 / 共43页
第八章 系统开发中的项目管理.ppt_第3页
第3页 / 共43页
第八章 系统开发中的项目管理.ppt_第4页
第4页 / 共43页
第八章 系统开发中的项目管理.ppt_第5页
第5页 / 共43页
亲,该文档总共43页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

1、第八章 系统开发中的项目管理,一、项目管理的主要任务 二、软件项目的计划阶段 三、项目管理工具,一、项目管理的主要任务,1、 软件项目中的组织结构与角色 1)客户:对要开发的新系统进行投资的个人或团体。对于内部开发,客户可能是专门成立的执行委员会或领导小组,对于大型项目还可能成立一个监督委员会。 2)用户:最终操作和使用要开发软件系统的人。用户可能就是客户,但并不总是。用户提供有关新系统需求的详细功能和操作的信息,而客户提供商业结构和战略方面的信息,这些是影响系统规划和设计的重要因素。 3)开发小组:由系统分析人员,程序员,软件配置人员、测试人员或文档管理员等组成的分工协作单位。 4)成员:项

2、目开发的最小单位。,一、项目管理的主要任务,2、项目经理的任务 1) 项目规模管理 2) 项目进度管理 3) 项目成本管理 4) 项目质量管理 5) 人力资源管理 6) 项目通信管理 7) 项目风险管理 ,1)项目规模管理,确定要开发的项目的规模并在软件开发过程中加以控制。 规模管理的目标: l 准确定义新系统的功能和潜能 l 检查确定的功能是必要的 控制功能集合以防止不适当的增长。员 需求扩充:开发活动和系统规范完成以后新增加的系统需求,从而引起项目规模的扩充。它可能发生在整个项目的各个阶段,如分析、设计阶段甚至在实现阶段。发生的阶段越晚,导致的问题越多。如新增一个字段可能导致的后果:数据库

3、结构、输入控制、界面控制、错误处理、报表输出、控制算法、更新算法、测试计划、用户文档。,1)项目规模管理,确定要开发的项目的规模并在软件开发过程中加以控制。 规模管理的内容: l 定义规模系统说明书:将系统要解决的问题和要实现的功能整理成文。 l 证实规模需求确认会议:与用户确认各种需求的优先级,保证关键功能得到确认。 l 控制规模规模变化日志:记录规模变化及其重要性和优先级,并估计对工作量、进度、资源和预算带来的影响。,1)项目规模管理,规模管理的技术: 软件规模度量 代码行技术LOC(KLOC):由有经验的人员对代码量进行估计。 优点:代码具有共性,可用估算模型多, 缺点:代码不能代表全部

4、,不同语言有差异,不适合OO 方法:L=(a+4m+b)/6n 功能点技术FP:以信息域特性和软件复杂性以功能点为单位进行估计。(输入项数、输出项数、查询项数、主文件数、外部接口数) 优点:与编程语言无关 缺点:主观性强 方法:将不同特性按复杂性分类,每个项数分配几个点数并汇总为UFP,将不同的使用技术按对规模的影响程序分配权重并汇总为TCF作为复杂度因子,FP=UFP*TCF,1)项目规模管理,规模管理的技术: 工作量估算 静态估算:E=A+B*(ev)c 面向LOC: Walston-Lelix:E=5.2*(KLOC)0.91 Baily-Basily:E=5.5+0.73*(KLOC)

5、 1.16 面向FP: Albrecht & Gaffney:E=-13.39+0.0545*FP Kemerer:E=-60.62*7.728*10-8*FP3,1)项目规模管理,规模管理的技术: 工作量估算 动态估算:E=(LOC*B0.333/P)3*(1/t)4 t:项目持续时间 B:技术因子,B=0.16(KLOC=5-15)B=0.39(KLOC70) P:生产率,从历史经验中取得,反映生产率对工作量的影响,如简单嵌入式软件P=2000,电信系统P=10000,大型商业系统P=28000,2)项目进度管理,确定各项任务的时间并在软件开发过程中加以控制。常见问题:客户要求在某一时间得

6、到最终产品,结果按客户要求而不是实际工作量来制定进度计划。 进度管理的目标: l保证进度表与要完成的工作完全一致 l准确度量已完成的工作以正确评定已完成进度 l有效利用和安排资源和技术以加速整体的进度,2)项目进度管理,进度管理的内容: l工作分解项目进度表:评估每项活动的工作量并确定活动之间的依赖关系。关键确定出所有的活动/真实估计出每项活动的工作量。使用方法:功能点分析,历史记录对照等。 l进度计划修正增加额外活动/时间不足/资源不足。 l进度控制里程碑、关键路径设定。坚持用完成/未完成来衡量里程碑80/20准则:20%的时间完成80%的进度并不代表剩下的80%的时间能完成20%的进度。,

7、2)项目进度管理,进度管理的技术: lGantt图 重新油漆旧房子,先刮旧漆,再刷新漆,最后清理窗户上的油漆。 共15名工人,5把刮旧漆的刮板,5把刷子,5把清理用小刮刀 问如何安排?,2)项目进度管理,进度管理的技术: lPERT/CPM图与关键路径,3)项目成本管理,成本决定项目最终的效益以及项目的可行性。项目成本的重要部分是人力资源成本这意味着时间与要付出的努力越多,项目成本就越高。 项目成本管理目标: l正确估计预期成本 l准确估算现金流和花费的时间安排 l控制项目进行过程中的花费 l正确记录实际项目的花费,3)项目成本管理,项目成本管理内容: l成本估算制定制度确定成本范围,如硬件,

8、开发工具,程序员工资。 l预测现金流效率因子:实际时间/估计时间 l花费控制在节约与浪费中平衡。如封闭开发。,4)项目质量管理,保证最终产品的质量达到要求。 软件质量要求: l易于使用 l满足预期目的 l鲁棒性 l可靠性,4)项目质量管理,软件质量管理内容 l规范与标准化 l里程碑与阶段评审 l文档控制 l测试 l外部确认与内部验证外部满足需求,内部相互一致(不产生冲突),5)人力资源管理,建立一个使开发小组成员能尽可能高速高效开展工作的环境。 管理目标: l人员获得 l人员培训对经验不足的小组成员进行培训,对项目开发制度与规范进行说明。 l小组构建项目整体结构/每个小组的结构。 l人员激励物

9、质,精神 l工作环境优化交流、网络、资料库,人员获得 在项目不同阶段制定不同层次的人员组合。 计划阶段:项目经理+系统分析员+用户 分析阶段:项目经理+更多系统分析员+业务专家+用户 设计阶段:项目经理+系统分析员+技术人员(数据库管理员,网络管理员,配置管理员) 实现阶段:以上+程序员,小组构建 项目组 民主分权式:没有固定负责人,任务协调人临时指定。全体组员协商一致解决问题,通信是平行的。 控制分权式:有固定负责人协调任务完成,指导下级领导人工作。小组负责人划分任务群体协调解决问题,小组内通信平行。 控制集权式:小组负责人管理顶层问题并负责协调,负责人与小组成员为上下级通信关系。,小组构建

10、 程序员组 民主制程序员组 优点:主观能动性,凝聚力,学术氛围浓 缺点:通信障碍(2-8名) ,缺乏权威,不适合多数成员技术不高的情况;程序员把模块打上自己的印迹。 主程序员组 类似外科手术中的关系,由一名能力较强的程序员为核心构建小组。 优点:专业化,层次性强,成员间无通信。 缺点:主程序员即懂技术又懂管理,缺乏后备程序员,小组构建 程序员组 现代程序员组常见形式 小型项目: 行政组长负责预算,进度,绩效评价等 技术组长只负责技术。,小组构建 程序员组 现代程序员组常见形式 大中型项目: 项目经理为中心 集中+民主,6)项目通信管理,保证项目小组能高效的沟通。包括信息的收集、传递与交流。 管

11、理目标: l保证及时和准确完整地收集必要的信息 l保证项目信息准确反映项目的情况 l保证项目组成员能获得最新的信息 l对重要项目信息进行记录和归档,6)项目通信管理,管理内容: l收集什么信息 l由谁收集信息 l谁需要信息 l如何收集信息 l如何记录信息 l如何验证信息 l如何传递信息 l如何汇报(时间,形式),7)项目风险管理,避免项目过程中可能发生的风险。 风险:项目失败的可能性。 管理目标: l确定潜在风险 l制订策略减少已确认的风险 l实施策略监测和控制风险,7)项目风险管理,管理内容: l风险识别:召开多种类型人员参与的开放式会议。列出项目可能存在的风险并按重要性排序。 l风险跟踪:

12、制定风险控制计划并定期对照,重新估计风险并更新重要风险列表。,7)项目风险管理,风险识别: l产品规模 l商业风险 l客户相关风险 l过程风险 l技术风险 l开发环境风险 l人员风险,8)项目配置管理,对软件开发过程中的变化进行管理的活动。 管理目标: l使变化更容易被适应 l在变化时尽可能减少代价 管理内容: l确定管理基线已经确定了的产品规格 l标识被管理对象(程序,文档,数据等) l版本控制 l变化控制,8)项目配置管理,管理技术版本控制系统 VSS CVS,9)项目获取管理,对项目资源获取的管理,主要是对一些硬件、软件、咨询顾问等资源供应商的选择。,二、软件项目的计划阶段,1、项目计划

13、阶段的主要活动 计划阶段一般配备2-3个系统分析员,一人出任项目经理。这几个人将是整个项目的核心,之后将以他们为中心建立其余小组。在计划阶段确认系统要完成的任务并认为可行后,即分配好资源、制订进度计划并做好预算,项目即可启动。 l 问题定义l 制订进度表l 可行性分析l 人员组织l 项目启动,1)问题定义,确认要解决的问题,制订预期收益明细表表明客户希望通过新系统实现的结果,确定新系统的能力,这三个部分构成系统作用域文档。必要时,可以用概念原型、系统关联图表示新系统的功能。,2)制订进度,任务分解 制定完成项目所需的各个任务的列表。 建立进度 PERT/CPM图 甘特图,3)可行性分析,经济可

14、行性 组织文化可行性 技术可行性 进度表可行性 资源可行性,经济可行性,1.成本效益分析:分析比较开发成本与收益以确定投资新系统的开发是有效益的. 2.现金流是够充足:确定成本所需的资金来源,成本: 工资 设备 工具与平台 第三方付款 培训 设施 支持人员 差旅及杂项,效益: 减少工员 提高工作能力 减少运行费用 减少错误损失 加快周转 减少损耗 ,计算方法: a.净现值 b.投资回收期 c.盈亏平衡点 d.投资回益率,4)人员组织,发现和安排适合本项目的人员,并在整个项目过程中组织和管理他们。 l制订资源计划 l确认参与人员 l确定参与用户 l小组划分 l培训和建组训练,5)项目启动,计划安排好了吗? 资源准备完成了吗? 人员训练了吗? GO!,三、项目管理工具,1、Microsoft Project 2、Microsoft Visual SourceSafe,1、Microsoft Project,项目起点,制定日历,任务管理,分解,链接,资源管理,定义,分配,项目跟踪,生成报表,固定单位固定工期固定工时,SS SF FS FF,资源信息 资源日历 资源费率 资源分配,Example,1、Microsoft VSS,数据库用户项目工作目录Check OutCheck In版本,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 教学课件 > 大学教育

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1