项目管理 软件目的需求开发与管理
软件项目管理软件项目需求管理
2.2.4编写需求文档
➢软件需求规格说明
(1)基本含义 规格就是一个预期的或已存在的计算机系统的表示,它可 以作为开发者和用户之间协议的基础来产生预期的系统. 软件需求规格SRS也称为功能规格说明,需求协议或系统规 格说明,精确地阐述一个软件系统必须提供的功能和性能 以及它所要考虑的限制条件,是对外部行为和系统环境 (软件,硬件,通信端口和人)接口的简洁完整的描述性 文档.
2.1.2软件需求层次
➢软件需求的四个抽象层次
原始问题描述 用户需求 系统需求 软件设计描述
4
2.1.2软件需求层次
软件需求的抽象层次如图2.2所示:
图2.2 软件需求的抽象层次
5
2.1.2软件需求层次
原始问题:描述是对要解决问题的叙述 用户需求:是用自然语言和图表给出的关于系统需要提供
10
2.1.2软件需求层次
系统需求的描述语言:
表2.1系统需求的描述语言
名称 说明
结构化 是对自然语言格式化, 语言 依赖于定义标准格式或
模板来表达需求描述
优点
缺点
表现能力强、易 于理解 、一致性 约束 、控制结 构 、图形化显示
仍然有一定程度的 二义性;细致程度 欠缺
PDL 源于像Java或Ada这样 可通过软件工具 表达系统功能的能
(2)形式化 需求规格描述方法有三种: 形式化方法、非形式化
方法和半形式化方法。 形式化方法:是具有严格数学基础的描述系统特征
的方法,具有准确、无二义性的特点,有助于验证有效 性和完整性。
非形式化方法:使用未作任何限制的自然语言,易 于理解和使用,但它固有二义性,且难以保证正确性、 可维护性,难以用计算机系统提供自动化的支持。
软件项目管理中的需求管理与变更管理
软件项目管理中的需求管理与变更管理1. 引言在软件项目管理中,需求管理与变更管理是软件开发过程中非常重要的一环。
正确的需求管理能够保证软件开发人员真正理解客户对软件系统的需求,从而开发出符合客户要求的软件;变更管理能够帮助团队应对客户需求的变化,及时做出调整,保证软件开发项目能够按时交付。
2. 需求管理需求管理是软件开发过程中的一项基本管理活动,也是软件开发的第一步。
在需求管理中,开发团队需要与客户多次沟通,理解客户的需求,分析客户的需求,确定开发目标,明确开发计划。
需求管理分为需求获取、需求分析、需求确认、需求跟踪等多个阶段。
2.1 需求获取需求获取是需求管理的第一步,其目的是收集客户的需求,确定客户的真正需求。
在需求获取中,软件开发团队需要耐心听取客户的需求,整理好客户对软件系统的要求,以便进一步分析和确认。
2.2 需求分析需求分析是在需求获取的基础上,分析客户需求,将需求明确具体化,并进行可行性分析。
在需求分析中,开发人员需要对客户的需求进行分类、整理、分析,明确需求的重要性、优先级,以便为开发进一步制定计划。
2.3 需求确认需求确认是需求管理中最为重要的一个环节。
在需求确认中,开发团队需要将对客户需求的分析结果提交给客户,进行确认和讨论。
在确定客户需求与软件开发的实际情况相符后,团队可以开始软件开发工作;若客户对需求分析结果存在异议,则需要进一步与客户沟通,以修改、确认需求。
2.4 需求跟踪需求跟踪是一项重要的需求管理工作。
在需求跟踪中,开发团队需要跟踪需求的变化,及时进行调整,确保软件开发项目可以按时交付。
此外,需求跟踪还可以帮助团队分析需求变更的原因和趋势,优化需求管理的流程。
3. 变更管理变更管理是软件开发过程中一项非常重要的管理活动,它负责跟踪、评估、协调和实现识别的软件问题,以期使软件产品能够按时按质量要求交付。
变更管理包括变更识别、变更控制、变更评估、变更实现等四个方面。
3.1 变更识别变更识别是变更管理中的第一步,其目的是识别软件开发过程中出现的问题,及早发现潜在的问题,并及时进行处理。
软件项目中的需求管理研究
关 键词 :软件 项 目 ,需求 ,管理
着用户 的需求应 该是合 理可 行的 ,项 目的 目标应 能满足 用户的 需 求 。需求管 理活动 就是建 立并维护 这种 共识 。 12 求 管理的 复杂性 .需 软件 需 求 是整 个 软件 开 发 项 目的 最 关键 的 一个 输 入 ,和传
引 言
~
统 的 生产 企 业相 比较 ,软件 的需 求 具有 模 糊性 、不 确定 性 、变 个 软件 项 目启 动 的 原 因是 由 于软 件 需求 的 存在 。无 论 采 化 性 和 主 观性 的特 点 ,它不 像 生 产 汽 车 、 电脑 等 硬件 的需 求 , 用何 种 软件 生存 周 期模 型 ,软 件 需求 是 每个 软 件开 发 过程 的基 是 有 形的 、客 观 的 、可描 述 的 、可 检 测 的 ,软 件 需 求是 软 件项 础 。需 求是 一个 软件 项 目的 开端 ,也 是 项 目建 设 的基 石 。有 资 目最 难把 握 的 问题 ,它的 复杂 性 主要 体 现 在 :需求 的描 述 、需 料 表 明 ,软件 项 目中 4 % ~ 6 % 的 问题 都是 在需 求分析 阶段埋 求 的完备程 度 、需求 开发 的工期 、需求 的细 致程度 五个 方面 。 O 0 第一 、 需求 的 描 述 问题 。缺 少 正 式的 完整 的 需 求文 档 浪费 下的 隐 患。软 件 开发 中返 工开 销 占开 发总 费 用 的 4 %,而 其 中 O 7% ~ 8 % 的返 工是 由需 求方 面错 误 所导 致的 。在 以往 失败 的 了大量 的 人 力物 力 ,但是 有 了需求 文 档又 出现 了新 的 问题 。在 0 0 软 件 项 目 中 ,8 % 是 由于 需 求分 析 的不 明确造 成 的 。 因此 ,一 用 户 方进 行 的需 求评 审 会 完全 是 走形 式 , 因为用 户根 本 不 去听 0 个软 件 项 目成功 的关 键 因 素 之 一就 是 对 需求 分析 的 把 握程 度 。 他 读那 上 百页 的 需求 文 档 。不 同层 次 的客 户 ( 户 )关 心 的 问 用 而项 目的整 体风 险往 往 表 现在 需 求分 析 不 明确 、业 务 流程 不合 题是 不一样 的 ,想要每 个客 户都成 为需 求专 家是不 现实 的。 第二 、 需求 的 完 备程 度 问题 。 需 求如 何做 到 没 有遗 漏? 如 理 。所 以需 求管理 是软件 项 目管理 的重要 一环 。 何 准确 划 定系 统 的范 围? 这 确 实是 一 个两 难 问题 ,稍 微 大一 点
软件开发的具体流程与管理制度详解
软件开发的具体流程与管理制度详解软件开发管理制度第⼀节总则第⼀条为规范⾃有软件研发以及外包软件的管理⼯作,特制定本制度。
本制度适⽤于公司总公司软件研发与管理,分公司参照执⾏。
第⼆条本制度中软件开发指新系统开发和现有系统重⼤改造。
第三条本制度中⾃⾏开发是指主要依赖公司⾃⾝的管理、业务和技术⼒量进⾏系统设计、软件开发、集成和相关的技术⽀持⼯作,⼀般仅向外购置有关的硬件设备和⽀撑软件平台;合作开发是公司与专业IT公司(合作商)共同协作完成IT应⽤的项⽬实施和技术⽀持⼯作,⼀般形式是公司负责提供业务框架,合作商提供技术框架,双⽅组成开发团队进⾏项⽬实施,IT系统的⽇常⽀持由研发部和合作商共同承担,研发负责内部⽀持,合作商负责外部⽀持;外包开发是指将IT应⽤项⽬的设计、开发、集成、培训等任务承包给某家专业公司(可以是专业的IT公司或咨询公司等),由该公司(承包商)负责应⽤项⽬的实施。
第四条软件开发遵循项⽬管理和软件⼯程的基本原则。
项⽬管理涉及⽴项管理、项⽬计划和监控、配置管理、合作开发管理和结项管理。
软件⼯程涉及需求管理、系统设计、系统实现、系统测试、⽤户接受测试、试运⾏、系统验收、系统上线和数据迁移。
第五条除特别指定,本制度中项⽬组包括业务组(营销部、运维部)、IT组(研发部和合作开发商)。
第⼆节⽴项管理第六条提出开发需求的营销部、运维部等业务部门参与公司层⾯⽴项,研发部进⾏⽴项的技术可⾏性分析,共同编写《⽴项分析报告》(附件⼀),开展前期筹备⼯作。
《⽴项分析报告》应明确项⽬的范围和边界。
第七条应⽤系统主要使⽤部门将《⽴项分析报告》上交公司进⾏⽴项审批,以保证系统项⽬与公司整体策略相⼀致。
第⼋条《⽴项分析报告》得到批准后,成⽴项⽬组(如果是外包开发,则成⽴外包商项⽬组;如果是合作开发,则与外包商共同成⽴合作开发项⽬组,以下统称“项⽬组”),项⽬组应包括业务组(由公司相关业务部门组成)和IT组(⾃⾏开发为研发部;外包开发为外包商成员;合作开发为研发部和外包商成员)。
软件需求管理制度
软件需求管理制度一、引言软件需求是软件开发的基础,正确、清晰和完整的需求对于软件项目的成功至关重要。
因此,建立一套科学、合理、可行的软件需求管理制度,对于提高软件开发的效率和质量具有重要意义。
本文将介绍一套软件需求管理制度的具体要求和实施流程。
二、软件需求管理制度的目的1. 确保软件需求的正确性和完整性,避免软件项目中需求变更的频繁发生。
2. 提高软件项目的可计划性和可控性,减少项目风险。
3. 加强开发人员与用户之间的沟通和协调,确保软件需求与用户期望一致。
4. 提高软件开发的效率和质量,减少项目资源浪费。
三、软件需求管理制度的内容1. 需求获取(1)建立需求收集机制,明确需求收集的渠道和方式。
(2)组织需求调研和需求分析工作,确保对需求的准确理解和全面收集。
(3)建立需求库,对收集到的需求进行分类和整理,形成清晰的需求文档。
2. 需求分析(1)设立专门的需求分析小组,由业务人员和项目开发人员共同参与。
(2)审查需求文档,梳理需求之间的依赖关系,划分基本需求和衍生需求。
(3)为每个需求分配唯一的标识符,确保需求的唯一性和可追踪性。
3. 需求确认(1)与用户进行需求确认,明确用户的需求和期望。
(2)建立需求确认记录,确保用户需求的一致性和稳定性。
(3)及时处理用户对需求的新要求和变更。
4. 需求变更管理(1)建立需求变更流程,包括变更申请、变更审批、变更实施和变更验证等环节。
(2)严格控制需求变更,实施变更评估和变更影响分析,避免不必要的需求变更。
5. 需求跟踪与追踪(1)建立需求跟踪表,记录每个需求的实现进度和质量状况。
(2)及时发现并解决需求实现过程中遇到的问题和阻碍。
6. 需求发布和交付(1)按照发布计划和交付计划,组织需求的发布和交付工作。
(2)建立需求发布和交付评审机制,确保需求的质量和可靠性。
四、软件需求管理制度的实施流程1. 需求管理小组负责制定和修订软件需求管理制度,明确责任和权限。
软件开发项目管理
管理目标1、所有关系人清晰明确地了解工程的需求和期望,努力做到满足工程所有关系人的不同需求;工程关系人包括:工程团队成员和工程团队外(内部/外部客户,内部/外部合作伙伴,经销商/客户等)。
2、工程管理三要素平衡(时间/成本/质量),即开发工程按需按时按质的完成。
3、目标:功能满足需求,设计支持变化,开发快速迭代,成果持续交付。
执行概述1、建立有效的工作流程保证工程的顺利进行,初期使用传统RUP过程,引入部分敏捷方法,团队磨合完成后逐步实现敏捷开发全流程管理。
2、明确工程目标,制定具有可行性的工程计划,有效明确的分解工程需求。
3、跟踪设计/开发/测试/回归/发布全流程,推动工程按预定计划执行。
4、解决工程过程中出现的问题和冲突,一般集中在需求不明/工作量或时长/开发难度/跨部门协调等几个方面。
5、调动开发团队的积极性,创造力,推动团队成员在工程过程中的学习成长。
6、风险识别、风险控制以及风险的预案。
工程管理1、需求阶段对工程进行技术可行性分析、技术评估、成本评估以及风险评估。
与需求提出方的代表进行需求讨论,明确工程的目标、价值。
确定工程范围、功能及优先级。
组建工程团队,特别要搞清楚工程的关键人。
工程启动会议,相关的关系人都必须参加。
2、设计阶段根据确认后的软件需求规格说明书,制定工程进度计划,工作任务分解(WBS);资源申请,工程涉及到的开发资源、测试资源、设计资源(包括人员和软硬件资源);数据库设计;系统设计;文档(包括系统用例、Demo、测试用例等);评审会议。
设计阶段结果交付一般为系统用例/系统原型/系统设计文档(概要设计和详细设计)/数据库设计文档等。
该阶段交付成果需要进行评审。
3、执行阶段(开发和测试)准备开发环境、测试环境。
跟踪,推动工程按计划进行。
工程成员以日报/工程负责人以周报的形式通报各关系人当前工程的进展情况。
按里程碑对阶段成果进行评估,以确保该阶段完成的质量。
代码审核,包括CS审核、SQL审核、WEB审核等。
企业级应用软件开发项目管理与实践
企业级应用软件开发项目管理与实践企业级应用软件是指为了满足企业管理和业务流程的需要,专门针对企业内部实现自我管理以及企业与外部系统协同工作的软件。
这类软件不仅涵盖面广,而且功能复杂,开发周期长,维护成本高,因此企业级应用软件开发项目的管理显得尤为重要。
本文将从需求分析、开发阶段、测试阶段、发布阶段和维护阶段五个方面来讲述企业级应用软件开发项目的管理与实践。
一、需求分析需求分析是企业级应用软件开发的第一步,对于软件的成功实施和保障运行以及协同工作都至关重要。
首先,项目经理应该与使用人员和管理人员进行沟通交流,收集用户需求、功能需求、性能需求以及安全需求等信息。
其次,开发团队应该对收集到的需求进行梳理和分类,确定需求的优先级。
最后,应对需求进行分析,明确需求的可行性,确定需求是否在预算范围内,评估开发难度和维护难度,确保需求能够满足客户实际需求并满足业务流程的需求。
二、开发阶段开发阶段是企业级应用软件开发的核心阶段,其关键是要满足项目预算、时间和质量的要求。
在开发阶段,需要遵循良好的开发流程。
首先,开发团队应该通过设立代码审查制度,确保代码质量符合标准。
其次,开发团队应该进行合理的任务分配和时间安排。
在开发过程中,应该及时进行代码提交、测试、维护和更新,确保高质量的软件交付。
三、测试阶段测试阶段是确保开发出来的软件质量的重要过程,包括集成测试、功能测试、性能测试和安全测试等。
在测试阶段,应该对项目进行有针对性的测试,持续改进测试方法。
首先,对测试用例的编写应该充分考虑测试覆盖率,确保每一个模块都能够得到完整的测试覆盖。
其次,在测试前应该进行测试计划的制定,以确保测试的全面性和有效性。
最后,应该建立缺陷数据库,记录测试过程中发现的缺陷,并及时进行修复。
四、发布阶段发布阶段是企业级应用软件开发的最后一个阶段,其目标是将软件交付给客户使用,并对客户进行培训。
在发布阶段,需要做好软件上线前的准备工作。
首先,应该制定上线计划,确保上线的流程和时间能符合客户的需求。
软件工程项目管理实践
软件工程项目管理实践软件工程项目管理是指对软件开发过程进行规划、组织、协调和控制,以实现项目目标的过程。
在软件开发过程中,项目管理的实践起着至关重要的作用。
本文将从项目计划、团队管理和风险控制等方面探讨软件工程项目管理的实践。
一、项目计划项目计划是软件工程项目管理的基础,具体包括项目目标、项目范围、项目进度和项目资源等四方面内容。
1. 项目目标项目目标是软件工程项目的价值所在,明确项目的目的和预期成果。
项目经理应与项目相关方充分沟通,确保项目目标明确、具体且可衡量。
2. 项目范围项目范围确定软件开发过程中应包含的功能和特性。
细化和明确项目范围有助于避免项目需求不断变更的问题。
3. 项目进度项目进度是软件工程项目按计划完成各个阶段和任务的时间安排。
项目经理需要根据项目目标和范围制定详细的项目进度计划,并对其进行有效管理和跟踪。
4. 项目资源项目资源包括人力资源、物质资源和财务资源等。
项目经理应根据项目计划的需求,合理分配和利用资源,确保项目的顺利进行。
二、团队管理团队管理是软件工程项目管理中不可或缺的一环,有效的团队管理可以提高团队成员的工作效率和积极性。
1. 团队建设团队建设包括团队成员的选拔、培训和激励等。
项目经理应根据项目需求和团队成员的能力和特长,合理分配任务和角色,搭建一个高效协作的团队。
2. 沟通协作良好的沟通协作是团队管理的关键。
项目经理应建立起开放、透明和高效的沟通机制,促进团队成员之间的有效沟通和协同工作。
3. 目标导向项目经理应明确团队的工作目标,并对团队成员进行激励和奖励,以提高工作的积极性和团队凝聚力。
三、风险控制软件工程项目管理过程中,风险无处不在,项目经理应积极主动地进行风险识别、分析和控制。
1. 风险识别项目经理应对项目的各个方面进行全面分析,识别和评估潜在的风险。
通过制定风险清单,及时发现并处理可能对项目造成威胁的问题。
2. 风险分析风险分析是对已经识别的风险进行进一步的评估和分析。
软件开发管理规范
软件开发管理规范一、引言软件开发管理规范旨在确保软件开发过程的高效性、质量和可靠性,以满足用户的需求并提供可持续的软件解决方案。
本文档将详细描述软件开发管理的各个方面,包括项目计划、需求分析、设计、编码、测试、发布和维护等。
二、项目计划1. 项目目标和范围定义项目的目标和范围,明确软件开发的目的和预期成果。
2. 项目计划和时间安排制定详细的项目计划,包括里程碑、任务分解和时间安排等,以确保项目按时交付。
3. 资源分配和管理确定项目所需的人力、物力和财力资源,并进行合理的分配和管理。
4. 风险管理识别项目风险并制定相应的风险管理计划,包括风险评估、应对策略和风险监控等。
三、需求分析1. 需求收集和确认与用户和相关利益相关者合作,收集和确认软件需求,确保需求的准确性和完整性。
2. 需求分析和规格说明对需求进行分析和整理,编写详细的需求规格说明文档,包括功能需求、非功能需求和用户界面设计等。
3. 需求变更管理建立需求变更管理机制,确保对需求变更的及时评估、审批和实施。
四、设计1. 系统架构设计设计软件系统的整体架构,包括模块划分、组件设计和接口定义等。
2. 数据库设计设计和规划数据库结构,包括表结构、关系和约束等。
3. 界面设计设计用户界面,包括界面布局、交互设计和视觉效果等。
五、编码1. 编码规范制定统一的编码规范,包括命名规则、代码风格和注释要求等,以提高代码的可读性和可维护性。
2. 编码实践采用合适的开发工具和技术,进行模块化开发、单元测试和代码审查等。
六、测试1. 测试策略和计划制定详细的测试策略和计划,包括测试目标、测试方法和测试资源的分配等。
2. 单元测试对软件的各个模块进行单元测试,确保模块的功能和性能符合预期。
3. 集成测试对软件的各个模块进行集成测试,验证模块之间的交互和整体功能。
4. 系统测试对整个软件系统进行系统测试,验证系统的功能、性能和稳定性。
七、发布和维护1. 发布计划制定详细的发布计划,包括版本管理、发布时间和发布方式等。
需求开发和管理过程 附需求调研指南全套
需求开发和管理过程附需求调研指南1. 前言1.1 意图和价值意图:明确需求,确保利益相关者的共同理解,并调整需求、计划和工作产品。
价值:确保客户的需求和期望得到满足。
1.2 适用范围本过程文档是项目经理需求开发人员(包括:售前市场人员、需求调研人员等)执行需求开发与管理过程活动的依据和指导。
本过程适用于公司所有软件项目,且贯穿于整个生命周期。
1.3 名词术语用户需求是用户对要建立的系统的要求描述,它主要说明用户“要做什么”、“想做什么”的问题。
软件需求也叫产品需求,是软件产品能否满足用户需求的要求描述,它主要说明软件产品“能做什么”、“不能做什么”的问题。
2. 过程定义2.1 角色和职责2.2 入口准则需求开发人员已经确定;初步的《项目计划》已经通过评审。
2.3 输入初步的《项目计划》;《项目合同》;《技术解决方案》;客户原始需求文档。
2.4 过程活动需求阶段包括需求开发和需求管理两个过程活动。
需求开发过程需求开发过程是获取用户需求并对用户需求进行分析整理形成软件需求的过程。
需求开发过程可以包括用户需求调研、用户需求分析、软件需求定义和软件需求评审四个过程,也可以根据具体情况对该过程进行裁减。
需求开发的结果文档包括用户需求类文档、软件需求类文档、有时为了满足软件产品前期设计的需要,也会制作形成业务模型、数据字典、系统开发原型(Demo)文档等。
所有的需求文档经过用户和开发方双方评审认可并签字后,形成项目的需求基线。
需求管理过程需求管理是在需求文档基线化后,对需求实现的跟踪以及当需求发生变更时,对需求变更进行控制和管理的过程。
需求管理包括变更控制、版本控制、需求跟踪过程。
需求管理同时包括变更的需求及相关需求之间的关系管理。
2.4.1 需求开发过程2.4.1.1 用户需求调研在项目正式立项后,项目经理组建需求开发团队,需求开发人员根据初步《项目计划》、客户原始需求文档(包括:市场人员从客户那里得到的初步需求文档,投标文件中定义的技术方案内容等),确定需求调研时间及需求获取相关干系人,并将此活动更新到《干系人计划》中,同时制定出《需求调研计划》。
浅析软件项目需求开发与管理工作中的问题及对策
需求 ,由需求 分析 人员对他们进 行引导 ,必要 时,有针 对性 的对他们进行 软件 项 目的相关知 识培 训,让客户能够更好 的 了解 软件项 目开发 知识 ,提高他们对 开发高质量系统需求重
要 性 的认 识 ,从 而 能清 楚表 达 自己 的 需 求 。
同行业 背景,不同层次 的人 员所 理解的含义也尽 不一样 ,这 些情况都会在认识上产生一定的分歧 。
2 需 求 分 析 不 完 整 . 在 需 求 分 析 阶 段 , 户 提 出 的 需求 仅 是 一 个 模 糊 的概 念 , 客 需 求 分 析 员 虽 然 已 按 客 户 的 描 述 进 行 需 求 分 析 ,但 这 只 是 从 开 发 者 的角 度 考 虑 , 并 没 有 能 完 全 站 在 客 户 角 度 去 搜 集 和 整 理 需 求 ,所 形成 的软 件 需 求 说 明文 档 无 法 得 到客 户 的 认 可 。
( )为了能够准 确把 握客户的需求,只有语言 、文字上 3 的 交流 沟 通 还 不 够 ,还 需 要 通 过 成 熟 的项 目进 行 演 示 ,或 搭 建直观 易懂的项 目需求模 型 ,由有实 际开发经验的项 目经理
作 为 需 求 分 析 人 员 向客 户 演 示 并 详 细 解 说 ,减 少 客 户 与 分 析
代 表 ,让 他 们 参 与 需 求 讨 论 。对 于 客 户 无 法 详 细 描 术清 楚 的
问题进行有效 的沟通 。当需求分析人 员就 系统需求与客户进
行 沟 通 时 ,需 求 分 析 人 员通 常 使 用 的是 专 业 的 计 算 机 术 语 , 而客户使用的是通俗 的行业 语言描述 。对 同样 的一句话 ,不
项工 作在很大程度上 依赖于需求获取者 的专 门知识 ,这种专 门知 识 可 以建 立 在 对 各 种 行 业 的 了解 上 , 也 建 立 在 对 项 目开
软件开发项目管理及实施方案
软件开发项目管理及实施方案第1章项目立项与规划 (4)1.1 项目背景分析 (4)1.2 项目目标与需求 (4)1.3 项目可行性研究 (5)1.4 项目规划与时间表 (5)第2章项目团队组织与管理 (6)2.1 团队组建与职责分配 (6)2.2 团队沟通与协作 (6)2.3 人员培训与技能提升 (7)2.4 团队绩效考核与激励 (7)第3章软件需求分析 (7)3.1 用户需求调研 (7)3.1.1 调研目标 (7)3.1.2 调研方法 (7)3.1.3 调研对象 (8)3.2 需求分析过程 (8)3.2.1 需求收集 (8)3.2.2 需求分析 (8)3.2.3 需求确认 (8)3.2.4 需求优先级排序 (8)3.3 需求规格说明书 (8)3.3.1 编写目的 (8)3.3.2 内容结构 (8)3.4 需求变更控制 (9)3.4.1 变更原因 (9)3.4.2 变更流程 (9)3.4.3 变更控制措施 (9)第4章软件设计与架构 (9)4.1 系统架构设计 (9)4.1.1 架构概述 (9)4.1.2 架构模式 (9)4.1.3 技术选型 (10)4.2 模块划分与接口设计 (10)4.2.1 模块划分 (10)4.2.2 接口设计 (10)4.3 数据库设计 (10)4.3.1 数据库选型 (10)4.3.2 数据库表设计 (10)4.3.3 数据库访问层设计 (11)4.4 设计评审与优化 (11)4.4.1 设计评审 (11)第5章编码与实现 (11)5.1 编程规范与技术选型 (11)5.1.1 编程规范 (11)5.1.2 技术选型 (12)5.2 代码编写与质量控制 (12)5.2.1 代码编写 (12)5.2.2 质量控制 (12)5.3 代码审查与测试 (12)5.3.1 代码审查 (12)5.3.2 测试 (12)5.4 版本控制与协同开发 (13)5.4.1 版本控制 (13)5.4.2 协同开发 (13)第6章软件测试 (13)6.1 测试策略与计划 (13)6.1.1 测试策略 (13)6.1.2 测试计划 (13)6.2 单元测试与集成测试 (13)6.2.1 单元测试 (13)6.2.2 集成测试 (14)6.3 系统测试与验收测试 (14)6.3.1 系统测试 (14)6.3.2 验收测试 (14)6.4 缺陷管理与跟踪 (14)第7章项目风险管理 (14)7.1 风险识别与评估 (15)7.1.1 风险识别 (15)7.1.2 风险评估 (15)7.2 风险应对策略 (15)7.2.1 需求风险应对策略 (15)7.2.2 技术风险应对策略 (15)7.2.3 人员风险应对策略 (16)7.2.4 进度风险应对策略 (16)7.2.5 质量风险应对策略 (16)7.2.6 成本风险应对策略 (16)7.2.7 外部风险应对策略 (16)7.3 风险监控与沟通 (16)7.3.1 风险监控 (16)7.3.2 风险沟通 (16)7.4 风险管理总结 (17)第8章项目进度与成本控制 (17)8.1 项目进度计划与监控 (17)8.1.1 进度计划编制 (17)8.1.3 进度更新与调整 (17)8.2 成本预算与控制 (17)8.2.1 成本预算编制 (17)8.2.2 成本控制方法 (17)8.2.3 成本控制措施 (17)8.3 资源分配与优化 (18)8.3.1 资源分配原则 (18)8.3.2 资源优化方法 (18)8.3.3 资源监控与调整 (18)8.4 项目调整与变更管理 (18)8.4.1 项目调整原则 (18)8.4.2 变更管理流程 (18)8.4.3 变更控制措施 (18)第9章项目交付与验收 (18)9.1 项目成果整理与交付 (18)9.1.1 成果整理 (18)9.1.2 成果审查 (19)9.1.3 成果交付 (19)9.2 客户验收与满意度调查 (19)9.2.1 客户验收 (19)9.2.2 满意度调查 (19)9.3 项目总结与经验教训 (19)9.3.1 项目总结 (20)9.3.2 经验教训 (20)9.4 后期维护与优化 (20)9.4.1 后期维护 (20)9.4.2 优化服务 (20)第10章项目质量管理 (20)10.1 质量管理体系构建 (20)10.1.1 制定质量方针和目标 (20)10.1.2 确定质量标准和规范 (21)10.1.3 设计质量组织结构 (21)10.1.4 分配质量责任和权限 (21)10.1.5 制定质量流程和程序 (21)10.1.6 建立质量培训和提升机制 (21)10.2 质量控制与检查 (21)10.2.1 质量计划制定 (21)10.2.2 质量控制工具和方法选择 (21)10.2.3 质量检查流程设计 (21)10.2.4 监控质量指标和关键绩效指标 (21)10.2.5 质量问题识别、分析和解决 (21)10.3 质量改进与持续优化 (21)10.3.1 质量改进计划制定 (21)10.3.2 质量改进团队组织与职责划分 (21)10.3.3 质量改进方法与工具应用 (21)10.3.4 质量改进实施与跟踪 (21)10.3.5 持续优化质量管理体系 (21)10.4 项目质量评估与审计 (21)10.4.1 质量评估标准与指标体系构建 (21)10.4.2 质量评估方法与工具选择 (21)10.4.3 质量审计流程设计 (21)10.4.4 质量评估与审计结果分析 (21)10.4.5 质量评估与审计报告编制 (21)第1章项目立项与规划1.1 项目背景分析信息技术的飞速发展,软件行业已成为国民经济的重要组成部分。
软件项目开发和管理规范V1
版本 V1.0项目编号记录号[2022]-公文001 号总页数24 页正文22 页编制2022 年 1 月15 日文件编号文件版本附录审核GLGF-RJ-ZZTXV1.0密级机秘年月日1. 软件项目管理概述 (3)2. 软件项目管理过程 (3)3. 软件项目管理内容 (5)3.1. 需求阶段管理 (5)3.2. 设计阶段管理 (7)3.3. 开辟阶段管理 (7)3.4. 测试阶段管理 (8)3.5. 维护阶段管理 (8)3.6. 工具管理 (8)3.7. 软件项目估算与进度管理 (9)3.7.1. 软件项目估算 (9)3.7.2. 进度安排 (10)软件项目管理是软件工程和项目管理的交叉学科,软件项目管理的概念涵盖了管理软件产品开辟所必须的知识、技术及工具。
根据美国项目管理协会PMI 对项目管理的定义可以将软件项目管理定义为:在软件项目活动中运用一系列知识、技能、工具和技术,以满足软件需求方的整体要求。
软件项目管理是为了使软件项目能够按照预定的成本、进度、质量顺利完成,而对成本、人员、进度、质量、风险等进行分析和管理的活动。
实际上,软件项目管理的意义不仅仅如此,进行软件项目管理有利于将开辟人员的个人开辟能力转化成企业的开辟能力,企业的软件开辟能力越高,表明这个企业的软件生产越趋向于成熟,企业越能够稳定发展。
软件生存周期包括可行性分析与项目开辟计划、需求分析、设计 (概要设计和详细设计)、编码、测试、维护等活动,所有这些活动都必须进行管理,在每个阶段都存在着权限角色控制、文档管理、版本控制、管理工具等,软件项目管理贯通于软件生命的演化过程之中。
为保证软件项目获得成功,必须对软件开辟项目的工作范围、要完成的任务、需要的资源、需要的工作量、进度的安排、可能遇到的风险等做到心中有数。
软件项目的管理工作开始于技术工作开始之前,在软件从概念到实现的过程中持续进行,最后终止于软件开辟工作结束。
根据公司的实际情况,结合软件工程及软件过程标准等,特制定我公司软件项目管理流程如下:注:带书名号《》的为项目开辟过程中需提交的文档。
需求开发与需求管理
另一个值得关注的方向是如何在需求开发和需求管理中更好地考虑用 户体验和情感因素,以提高软件产品的质量和用户满意度。
THANKS
感谢观看
相互依赖
需求开发和需求管理相互依赖,前者为后者提供基础,后者 在前者基础上进行管理和优化。
相互促进
良好的需求开发能够提高需求管理的效率,而有效的需求管 理又能促进需求的开发和实现。
共同目标
两者共同致力于满足客户需求,提高项目成功率。
05
案例分析
案例一
总结词
精准定位,快速迭代
详细描述
该电商平台通过市场调研和用户访谈,精准定位用户需求,快速迭代产品功能, 不断优化用户体验,从而在竞争激烈的市场中脱颖而出。
需求开发的流程
需求收集
通过与利益相关者的沟通,收集项目的需求和业务需求 。
需求编写
将分析后的需求编写成详细的需求规格说明书,包括功 能、性能、约束等方面的要求。
ABCD
需求分析
对收集到的需求进行分类、整理和筛选,明确需求的优 先级和重要性。
需求评审
对编写完成的需求规格说明书进行评审,确保需求的准 确性和完整性。
需求开发的方法
原型法
通过制作原型来展示产品的基本 功能和界面,帮助利益相关者更 好地理解需求。
调查问卷法
通过调查问卷的形式收集利益相 关者的意见和建议,了解他们的 需求和期望。
面谈法
与利益相关者进行面对面的交流, 深入了解他们的业务和需求,确 保需求的准确性和完整性。
03
需求管理
需求管理的定义
在需求开发的基础上,通过需求 管理对需求进行跟踪、调整和优 化,确保客户需求得到满足。
02
需求管理降低项目 风险
解析企业软件开发项目的需求管理
计 、 写代码、 改测试用例 、 重 修 调整项 目计划等等。需求的变化好像 为 项 目的正 常 的进 展 带 来 不 尽 的麻 烦 , 么 办 ? 只 有 通过 需 求 管理 怎 随着信息时代 的发展 , 计算机软件的需求愈来愈复杂, 规模愈来 使 需 求 在 受控 的状 态 下 发 生 变化 , 不 是 随 意 变 化 , 求 管 理 就 是 而 需 愈大, 而且 随着 企 业 的 发展 和 工 作 过 程 重 组 , 求 变更 已愈 来愈 成 为 需 要按照标准 的流程来控制需求 的变化。难题随之而来 , 需求中的变 必然。 在企业软件项 目的开发过程 中, 需求变更贯穿了软件项 目的整 化 一 般 不 是 突 发 的 革 命 性 的 变 化 ,最 常 见 的 是 项 目 需 求 的 渐 变 个生命周期, 在软件的项 目立项、 研发 及维 护各阶段 , 用户经验 的增 (rjc c p re ) 题 , Poe tS o e Ce p问 这种 渐 变很 可 能是 客 户 与开 发 方都 没 加、 对软件使用感受的变化 以及整个行业的新动态 , 都为软件带来不 有意识 到的 , 当达到一定程度 时 , 方才蓦然 回首 , 双 发现 已经物是人 断完善功能、 优化性能、 提高用户友好性的要求。在软件项 目管理过 非 , 了一 番 天 地 。 换 程 中 , 目经 理 经 常 面 对 用 户 的需 求 变 更 。 果 不 能有 效 处 理 这 些需 项 如 3 需求管理策略 求 变 更 , 目计 划 会 一再 调 整 , 件 交 付 日期 一再 拖 延 , 目研 发 人 项 软 项 需 求 管理 需要 遵 守 以下 策 略 : 员 的 士气 将越 来 越 低 落 , 直 接 导 致项 目成 本 增加 、 量 下 降及 项 目 将 质 31 需 求 一 定 要 与 投 入 有 必 然 的 联 系 需 求 一 定 要 与 投 入 有 必 . 交付 日期 推后 。这 决 定 了项 目组 必须 拥 有 需 求管 理 策 略 。 然 的联 系 , 否则 如 果 需 求 变更 的成 本 由开 发 方 来承 担 , 项 目需 求 的 则 需求管理是软件开发生命周期 的初始阶段 ,它对最终提交 的软 变 更就 成 为 必 然 了 。 人们 常说 世 上 没 有免 费 的 午餐 , 同样 也 不 应该 有 件 产 品 的 质量 起着 至 关 重 要 的作 用。 有资 料 统 计 , 软件 项 目 4 %一 0 免费的需求变更。 但是, 接受需求变更 目前却是软件企业不得不咽下 6 %的问题都源于需求分析 。所 以, 0 重视 需求、 谨慎对待、 严密分析 , 的苦果。 以, 所 在项 目的开始无论是开发方还是 出资方都要明确 这一 是每一个开发者应该持有的正确态度。建立软件需求管理过程 的目 条: 需求变, 软件开发的投入也要变。 的在于用户和软件项 目组之间形成共 同的理解 ,这种共同理解应体 32 要 充 分 理 解 客 户 提 出来 的 需 求 开 发 者 应 该 理 解 客 户 的需 - 现在用户需求的文档化确认和对用户需求的控制 中,并保证项 目的 求 , 果 这点 做 不 到 , 面 的 工作 是 没 有 意 义 的 , 以 , 种 在没 有 理 如 后 所 那 计划 、 工作产品和活动都与需求一致。 解 需求 的情况下 , 就仓促开发的做 法是不合适的。 1需 求 管 理 复杂 性 分 析 33 需 求 的变 更 要 经 过 出资 者 的认 可 需 求 的 变 更 引 起 投 入 的 . 软件需求是整个软件开发项 目的最关键 的一个输入 ,和传统的 变 化 , 以 要通 过 出 资者 的认 可 , 样 才会 对 需 求 的 变更 有 成 本 的概 所 这 生产 企业相 比较 , 软件 的需求具 有模糊 性、 不确定性 、 变化性和主观 念 , 够慎 重地 对 待 需 求 的变 更 。 能 性 的特 点 , 同 于 生 产汽 车 、 不 电脑 等 硬 件 的需 求 , 有 形 的 、 观 的 、 是 客 34 做 好 需 求 文 档 的版 本 管 理 记 录 用 户 需 求 、 . 系统 需 求 、 件 软 可描 述 的 、 可检 测 的 , 件 需 求 是 企 业 软 件 项 目最 难 把 握 的 问题 , 软 其 分 配需 求 的 文档 都 要作 为 基 线确 定 下 来 , 好 相 关文 档 的管 理 工作 。 做 复 杂性 体 现 在 以 下 方面 : 需 求 的基 线 是 指是 否容 许 需 求 变更 的 分 界 线 ,需 求 分析 人 员在 充 分 11 需 求 的描 述 问题 。 少 正 式 的 、 整 的 需 求文 档 浪 费 了大 量 . 缺 完 与 客户 用 户 进 行 沟通 的基 础 上形 成 第 一 个 版本 的需 求 文档 ,这个 需 的人 力物 力 , 是 有 了 需 求 文档 又 出 现 了 新 的 问题 。 用 户 方进 行 的 但 在 求文档在通过需求评审后即可以建立第一个需求基线。此后每次需 需求评审会完全是走形式 ,因为用户根本不去听那上百页的需求文 求变更并经过需求评审后 , 都要重新确定新的需求基线 , 以免将来用 档 。不 同 层 次 的客 户 ( 户 ) 心 的 问题 是 不一 样 的 , 要 每 个客 户都 用 关 想 户 需 求发 生 变 更 时 ,原 来 的 需 求无 法 查 找 。 为有 效 进行 需 求 变 更控 成 为 需求 专 家 是 不现 实 的。 制, 必然要做 的工作就是保存好各个版本 的需求基线, 维护需求基线 1 需求的完备程度问题 。 . 2 需求如何做 到没有遗漏? 如何准确划 文档 , 以备 不 时之 需 。 定 系统 的范 围 ? 确 实 是 一 个两 难 问题 , 微 大 一 点 的 系统 要 想 穷举 这 稍 35 小 的需求 变更也要经过正规 的需求管理流程 小 的需 求变 . 需 求 几 乎 是 不 可能 的 , 次 开 需 求 评 审 会 时 , 会 冒 出 新 的 需 求 , 每 总 以 更 也要 经 过 正 规 的 需求 管 理 流程 , 则会 积 少 成 多 。在 实践 中 , 们 否 人 至于系统没有一个准确 的范围界定。 即使是这样 , 系统还是要开发, 往 往 不愿 意 为 小 的 需求 变 更 去执 行 正 规 的 需 求管 理 过程 ,认 为 降低 系 统 的范 围还 要硬 性 的划 定 一 个 , 而 建 立一 个 基 线 。 从 了开发 效 率 ,浪 费 了时 间。 正 是 由于 这 种 观念 才使 需 求 的渐 变 不可 1 需 求 开发 的工 期 问题 。在 需 求 上 花 费 了大 量 的 时 间 , 户 、 . 3 客 控 , 终 导 致项 目的失 败 。 最 企 业 是 否 能够 忍 受? 为 了确 保 需 求 的正 确 性 , 备 性 , 目经理 往 往 完 项 36 精 确 的需 求与 范 围定 义并 不 会 阻 止 需 求 的 变 更 并 非 对 需 . 坚 持 要在 需求 阶 段 花 费 大量 的时 间 ,但 是 客 户 与 企业 的高 层领 导却 求 定 义 的越 细 , 能 避 免 需 求 的渐 变 , 是 两个 层 面 的 问题 。 太 细 的 越 这 会 为 项 目迟迟 看 不 到 实 际可 运 行 的软 件 担 心 不 已 ,他 们 往 往 会催 促 需 求定 义对 需 求 渐 变没 有 任 何 效 果 , 为 需求 的变 化是 永 恒 的 , 非 因 并 项 目组尽 快往前推进, 而项 目组 的成员往往也会被系统 复杂 、 变的 善 需 求 写 细 了就 不 会 变化 了。 需求折腾 的筋疲力尽, 希望尽快结束需求分析 的相关工作。 37注意沟通 的技巧 由于需求的变更可能来 自投资方、 . 也可能 1 需求的细致程度问题 。 . 4 需求到底描述到多细 , 才算可以结束 来 自用户方和开发方 ,作 为投资方可能不愿意为需求的变更付出更 了?仁者见仁 , 智者见智 , 并没有定论 , 如果时间允许 , 要想细总可以 细 下 去 的 。 是 , 求 的 周期 越 长 , 能 的 变 化越 多 , 设 计 的限 制越 多的成 本,而开发方有可能主动的变更 了需求 目的是使软件做的更 但 需 可 对 于是作为需求管理者 , 目经理 需要采用各种沟通技巧来使项 项 严 格 , 需 求 的共 性 提 取 要 求 越 高 , 以 只 要 客 户 ( 户 )需 求 分析 精致。 对 所 用 、 目的各方各得其所。 人员、 设计人员、 测试人员认 为描述清 楚了, 可以进入设计 阶段 了。 就 4 结 束语 15需求的变化问题。在软件开发过程 中如果只有一条真理 的 . 需 求管 理 是 软 件项 目中一 项 十 分重 要 的工作 ,据 调查 显 示 在 众 话 , 一 定 是 : 求 的 变 化是 永 恒 的 , 求 不 可 能是 完 备 的 。 件 开发 那 需 需 软 由于需求原因导致的约 占到 4 % , 5 因此有效 的过 程 实 际上
软件开发与IT项目管理制度
软件开发与IT项目管理制度第一章总则第一条为了规范和提高公司软件开发与IT项目管理的质量,保证项目的顺利进行并取得良好的效果,订立本制度。
第二条本制度适用于公司内全部软件开发和IT项目管理活动,包含但不限于需求分析、项目计划、需求开发、系统设计、编码及测试等各个阶段。
第三条公司软件开发与IT项目管理应遵从本制度,并结合具体情况,订立项目管理实施计划,确保项目依照规定的流程和要求进行。
第二章项目管理流程第四条项目启动阶段1.项目启动前,项目经理应与甲方进行充分的沟通,明确项目目标、范围、实施计划和资源需求等。
2.项目经理应编制项目启动报告,包含项目背景、目标、需求分析、实施方案、风险评估等内容,并提交给上级领导进行审批。
3.审批通过后,项目经理组织项目团队成立会议,明确项目目标、团队角色和职责,并订立认真的项目计划和工作分解结构(WBS)。
第五条需求分析阶段1.项目经理应依据项目目标和计划,组织需求分析小组进行需求调研和分析,编制需求规格说明书,并与甲方进行确认和评审。
2.需求规格说明书应包含需求描述、功能需求、性能需求、界面设计、安全性要求等内容,确保需求能够满足甲方的实际需求。
第六条系统设计阶段1.项目经理应依据需求规格说明书,组织系统设计小组进行系统设计工作,编制认真的系统设计文档,并与甲方进行确认和评审。
2.系统设计文档应包含系统结构设计、模块设计、数据库设计、界面设计等内容,确保系统能够满足甲方的需求并具备良好的可扩展性和可维护性。
第七条编码和测试阶段1.项目经理应依据系统设计文档,组织开发团队进行编码和测试工作,确保代码质量和系统功能的完整性。
2.在编码过程中,开发人员应遵从统一的编码规范,编写清楚、可读性强的代码,并进行单元测试和代码审查。
3.测试人员应依据测试计划和测试用例,进行系统集成测试、功能测试、性能测试等各项测试工作,确保系统质量和稳定性。
第八条项目验收和上线阶段1.项目经理应依据项目计划和甲方要求,组织项目验收工作,包含系统验收测试、功能验收、性能验收等环节,并记录验收结果。
软件项目管理办法
软件项目管理办法(试行)第一章总则第一条为加快本行信息化建设进程,促进新产品开发与创新,规范软件项目开发管理,确保软件项目开发工作按时、保质完成,根据《商业银行信息科技风险管理指引》等相关制度规定,特制定本办法。
第二条本办法所称软件项目是指以促进本行业务发展和提高管理效率为目的的信息化建设项目。
第三条软件项目管理的任务是加强项目在立项、需求调研、设计、开发、测试、运行和维护过程中的组织实施、质量控制和监督检查。
第二章职责分工第四条信息科技管理委员会在其职责范围内负责软件项目的立项审批。
第五条信息科技管理委员会办公室负责受理软件项目立项申请,并搜集立项申请部门提供的可行性报告等相关资料,上报信息科技管理委员会审议。
同时,负责组织软件项目上线前的评审及验收。
第六条科技开发部是软件项目开发的主要承办部门,负责软件项目的研发、运行、维护和监控,并负责提供日常的科技服务和技术支持。
第七条业务主管部门应全程参与软件项目的开发,负责本部门、本业务条线相关软件项目的立项申请、业务需求、测试、培训、上线、验收等工作。
其中,科技管理类项目的业务主管部门为科技开发部。
第三章软件项目分类第八条软件项目类别(一)业务及交易类项目:以辅助会计记账、业务审批等银行内部业务操作为目的,记录银行基本交易信息数据,主要包括核心系统、支付系统。
(二)渠道及服务类项目:为银行客户开展金融业务活动提供服务渠道和手段,记录以银行客户行为特征的信息数据,主要包括ATM、POS、电话银行、网上银行、中间业务等系统。
(三)分析及管理类项目:为银行内部管理和外部监管提供必要的分析数据和管理信息,主要包括办公自动化、人力资源、财务、信贷、客户关系等管理信息系统。
第九条重要信息系统重要信息系统是指支撑重要业务,其信息安全和服务质量关系公民、法人和其他组织的权益,或关系社会秩序、公共利益乃至国家安全的信息系统。
重要信息系统包括面向客户、涉及账务处理且实时性要求较高的业务处理类、渠道类和涉及客户风险管理等业务的管理类信息系统,以及支撑系统运行的机房和网络等基础设施。
软件的目标与项目计划
软件的目标与项目计划在关系到软件项目成功与否的众多因素中,软件的目标与项目计划、成本估算、进度计划、人员分配、软件配置管理、风险管理、软件质量管理和软件工程文件规范等都是与项目管理直接相关的因素。
由此可见,软件研发项目管理的意义至关重要。
软件项目管理是包括项目计划、项目组织和控制的一系列活动。
而软件计划就是对软件开发过程的详尽描述与安排。
一、软件开发项目的特点了解软件开发项目的特点对于项目的计划制定和管理控制是非常必要的。
与其他类型项目的共同点:项目成功与否不仅取决于项目过程中所采用的技术方法工具,还取决于项目管理的水平,特别是计划与控制的水平。
与其他类型项目的不同点:(1) 软件产品和其他产品不同,软件产品是一种“逻辑”产品,是无形的,没有物理属性的,看不见、摸不着、难以理解。
(2) 需求难以明确且频繁变更:由于用户的成熟度或责任心的原因,用户开始无法给出明确的需求。
在开发过程中,需求可能要经常修改,因此需要经常地修改程序与文档。
(3) 难以在早期发现问题:需求不明确,加上后期修改可能没有进行全局性的考虑,产生的问题难以从早期的文档中直观地发现,需要等系统设计出来后才会发现。
(4) 项目成员对文档的重视不够,符合用户需求的高质量软件,需要依赖于大量准确规范的文档编辑工作,但项目组成员对它并不感兴趣,很少有人愿意认真去做,因而直接影响了软件的质量。
(5) 劳动密集型+智力密集型:软件开发过程需要大量高强度的脑力劳动,这些劳动非常细致、高度复杂、容易出错,质量难以用简单的度量来衡量,使得软件的正确性难以保证。
对于不深入地掌握软件工程知识或缺乏软件开发实践经验的人员,是难以做好软件开发项目管理工作的。
二、项目计划目的与作用根据软件能力成熟度模型(简称 CMM)集成 CMMI,软件开发项目计划的目的是:建立和维护定义项目活动的计划。
项目计划属于 CMMI 的第二级,其过程域包括开发项目计划、与相关人员交流、获取对计划的承诺、维护计划。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
项目管理——软件目的需求开发与管理需求开发与管理是软件项目中一项十分重要的工作,据调查显示在众多失败的软件项目中,由于需求原因导致的约占到45%,因此,需求工作将对软件项目能否最终实现产生至关重要的影响。
虽然如此,在项目开发工作中,很多人对需求的认识还远远不够,从本人参与或接触到的一些项目来看,小到几十万元,大到上亿元的软件项目的需求都或多多少的存在问题,有的是开发者本身不重视原因、有的是技术原因、有的是人员组织原因、有的是沟通原因、有的是机制原因,以上种种原因都表明做好软件需求开发是一项系统工作,而不是简单的技术工作,只有系统的了解和掌握需求的基本概念、方法、手段、评估标准、风险等相关知识,并在实践中加以应用,才能真正做好需求的开发和管理工作。
本文将通过介绍关于软件需求的基本知识和个人在实际工作中总结的一些经验,帮助读者了解软件需求,学习需求开发的一些基本方法,避免因需求原因而导致的项目失败。
1 什么是软件需求和需求工程1.1 软件需求的定义在IEEE软件工程标准词汇表(1997年)中定义软件需求为:(1)用户解决问题或达到目标所需的条件或能力。
(2)系统或系统部件要满足合同、标准、规范或其它正式规定文档所需具有的条件或能力。
(3)一种反映上面(1)或(2)所描述的条件或权能的文档说明。
实通俗的讲,“需求”就是用户的需要,它包括用户要解决的问题、达到的目标、以及实现这些目标所需要的条件,它是一个程序或系统开发工作的说明,表现形式一般为文档形式。
1.2 需求工程的定义需求分析的过程,也叫做需求工程和需求阶段,它包括了需求开发和需求管理两个部分。
需求开发是指从情况收集、分析和评价到编写文档、评审等一系列产生需求的活动,分为四个阶段:情况获取、分析、制订规格说明和评审。
这四个阶段不一定是遵循线性顺序的,他们的活动是相互独立和反复的。
需求管理是软件项目开发过程中控制和维持需求约定的活动,它包括:变更控制、版本控制、需求跟踪、需求状态跟踪等工作。
2 需求分析的风险由于需求分析的参与人员、业务模式、投资、时间等客观因素的影响和需求本身具有主观性和可描述性差的特点,因此,需求分析工作往往面临着一些潜在的风险。
这些风险主要表现在:(1)用户不能正确表达自身的需求。
在实际开发过程中,常常碰到用户对自己真正的需求并不是十分明确的情况,他们认为计算机是万能的,只要简单的说说自己想干什么就是把需求说明白了,而对业务的规则、工作流程却不愿多谈,也讲不清楚。
这种情况往往会增加需求分析工作难度,分析人员需要花费更多的时间和精力与用户交流,帮助他们梳理思路,搞清用户的真实需求。
(2)业务人员配合力度不够。
有的用户日常工作繁忙,他们不愿意付出更多的时间和精力向分析人员讲解业务,这样会加大分析人员的工作难度和工作量,也可能导致因业务需求不足而使系统无法使用。
(3)用户需求的不断变更。
由于需求识别不全、业务发生变化、需求本身错误、需求不清楚等原因,需求在项目的整个生命周期都可能发生变化,因此,我们要认识到,软件开发的过程实际上是同变化做斗争的过程,需求变化是每个开发人员、项目管理人员都会遇到的问题,也是最头痛的问题,一旦发生了需求变化,就不得不修改设计、重写代码、修改测试用例、调整项目计划等等,需求的变化就像是万恶之源,为项目的正常的进展带来不尽的麻烦。
(4)需求的完整程度。
需求如何做到没有遗漏?这是一个大问题,大的系统要想穷举需求几乎是不可能的,即使小的系统,新的需求也总会不时地冒出来。
一个系统很难确定明确的范围并把所有需求一次性提出来,这会导致开发人员在项目进展中去不断完善需求,先建立系统结构再完成需求说明,造成返工的可能性很大,会给开发人员带来挫折感,降低他们完成项目的信心。
(5)需求的细化程度。
需求到底描述到多细,才算可以结束了?虽然国家标准有需求说明的编写规范,但具体到某一个需求上,很难给出一个具体的指标,可谓仁者见仁,智者见智,并没有定论。
需求越细,周期越长,可能的变化越多,对设计的限制越严格,对需求的共性提取要求也越高,相反,需求越粗,开发人员在技术设计时不清楚的地方就越多,影响技术设计。
(6)需求描述的多义性。
需求描述的多义性一方面是指不同读者对需求说明产生了不同的理解;另一方面是指同一读者能用不同的方式来解释某个需求说明。
多义性会使用户和开发人员等项目参与者产生不同的期望,也会使开发、测试人员为不同的理解而浪费时间,带来不可避免的后果便是返工重做。
(7)忽略了用户的特点分析。
分析人员往往容易忽略了系统用户的特点,系统是由不同的人使用其不同的特性,使用频繁程度有所差异,使用者受教育程度和经验水平不尽相同。
如果忽略这些的话,将会导致有的用户对产品感到失望。
(8)需求开发的时间保障。
为了确保需求的正确性和完整性,项目负责人往往坚持要在需求阶段花费较多的时间,但用户和开发部门的领导却会因为项目迟迟看不到实际成果而焦虑,他们往往会强迫项目尽快往前推进,需求开发人员也会被需求的复杂和善变折腾的筋疲力尽,他们也希望尽快结束需求阶段。
3 如何做好需求工作需求分析是软件项目开发中最困难的一项工作,它不仅要求分析人员具有丰富的需求分析经验和良好的专业素质,还要求分析人员具有良好的学习能力、公关能力、语言能力和组织能力。
在实际工作中分析人员要面对不同的单位、不同的部门、不同的人员、不同的文化、不同的关系、不同的管理水平等等不同的情况,面对如此纷繁复杂的环境,如何做好需求分析工作?首先需要建立一个有效的工作机制,只有建立了工作机制,才能保证需求工作按照既定方案执行,需求开发和管理的参与者才会在一种有序的状态下工作。
其次才是充分运用工作机制和个人能力去获取问题、分析问题、编写需求文档和进行需求管理。
3.1 建立需求分析工作机制需考虑的几个因素(1)抓住决策者最迫切和最关心的问题,引起重视。
用户方决策者对项目的关心重视程度是项目能否顺利开展的关键,决策者的真实意图也是用户方的最终需求,因此,在开发过程中要利用一切机会了解决策者关心的问题,同时也要让他们了解项目的情况。
在诸如谈判、专题汇报、协调会议、领导视察、阶段性成果演示等过程中用简短明确的语言或文字抓住领导最关心的问题,引导他们了解和重视项目的开发,当决策者认识到项目的重要性时,需求分析工作在人力、物力、时间上就有了保障。
(2)建立组织保障,明确的责任分工。
项目开发一般都会成立相应的项目组或工程组,目前,常见的组织形式是:产品管理组、质量与测试组、程序开发组、用户代表组和后勤保障组,各组的主要分工是:产品管理组负责确定和设置项目目标,根据需求的优先级确定功能规范,向相关人员通报项目进展。
程序管理组负责系统分析,根据软件开发标准协调日常开发工作确保及时交付开发任务,控制项目进度。
程序开发组负责按照功能规范要求交付软件系统。
质量与测试组负责保证系统符合功能规范的要求,测试工作与开发工作是独立并行的。
用户代表组负责代表用户方提出需求,负责软件的用户方测试。
后勤保障组负责确保项目顺利进行的后勤保障工作。
(3)建立良好的沟通环境和氛围。
分析人员与用户沟通的程度关系到需求分析的质量,因此建立一个良好的沟通氛围、处理好分析人员与用户之间的关系显得尤其重要,一般情况,用户作为投资方会有一些心理优势,希望他们的意见得到足够的重视,分析人员应该充分的认识到这一点,做好心理准备,尽量避免与他们发生争执,因为我们的目的是帮助用户说出他们的最终需要。
在沟通时分析人员应注意以下几个方面:1)态度上要尊重对方,但不谦恭。
谦恭可能会让用户一时感到满意,但对长期合作并没有好处,尤其是在发生冲突的时候,用户会习惯性地感到自己的优势,而忽略分析人员地意见。
2)分析人员要努力适应不同用户的语言表达方式。
每个人都有自己的表达方式,所以优秀的分析人员应该是一个优秀的“倾听者”,他们能很快的适应用户的语言风格,理解他们的意思。
3)善于表达自己,善于提问。
分析人员在开口前应该先让对方充分表达他的意思,在领会了后,自己再说,尽量不要抢话。
4)工作外的交流有助于增进理解,加强沟通。
(4)需求质量控制要制度化需求的变化是软件项目不可避免的事实,因此需求质量控制是一项艰苦的工作,要保证该项工作的顺利实施,就必须有制度保证,这个制度可以在项目质量控制方案中制定,该方案主要是具体化、定量化的描述用户要求,形成全面、一致、规范的软件需求分析规格说明书,明确需求分析规格说明书的工作程序和要素,规范开发活动,为后续软件设计、实现、测试、评审及验收提供依据。
在方案中要明确项目组各部门关于需求质量控制的职责,制定需求分析的工作程序,包括编制需求分析工作计划、编制《需求分析说明书》、《需求分析规格说明书》的评审和确认、《需求分析规格说明书》修改控制、确定需求质量控制的质量记录文档规范等内容。
3.2 需求开发与管理的一些方法需求开发是一项复杂的工作,使用的方法也很多,不同的开发方式有不同的方法,这里简单介绍一些相关的方法:(1)绘制关联图:绘制系统关联图是用于定义系统与系统外部实体间的界限和接口的简单模型。
(2)可行性分析:在允许的成本、性能要求下,分析每项需求实施的可行性,提出需求实现相关风险,包括与其它需求的冲突,对外界因素的依赖和技术障碍。
(3)需求优先级:确定使用实例、产品特性或单项需求实现的优先级别。
以优先级为基础确定产品版本将包括哪些特性或哪类需求。
(4)系统原型:当用户自身对有的需求不十分清楚时,我们可以建立一个系统原型,用户通过评价原型更好地理解所要解决的问题。
(5)图形分析模型:绘制图形分析模型是编制软件需求规格说明重要手段。
它们能帮助分析人员理清数据、业务模式、工作流程以及他们之间的关系,找出遗漏、冗余和不一致的需求。
这样的模型包括数据流图、实体关系图、状态变换图、对话框图、对象类及交互作用图。
(6)数据字典:数据字典是对系统用到的所有数据项和结构的定义,以确保开发人员使用统一的数据定义。
在需求阶段,数据字典至少应定义客户数据项,确保客户与开发小组是使用一致的定义和术语。
(7)质量功能调配:质量功能调配是一种高级系统技术,它将产品特性、属性与对客户的重要性联系起来。
该技术提供了一种分析方法以明确哪些是客户最为关注的特性。
它将需求分为三类:期望需求、普通需求、兴奋需求。
需求管理的目的就是要控制和维持需求事先约定,保证项目开发过程的一致性,使用户得到他们最终想要得产品。
需求管理的方法主要包括以下一些方面:1)确定需求变更控制过程。
制定一个选择、分析和决策需求变更的过程,所有的需求变更都需遵循此过程。
2)进行需求变更影响分析。
评估每项需求变更,以确定它对项目计划安排和其它需求的影响,明确与变更相关的任务并评估完成这些任务需要的工作量。