2022年软件过程规范推荐 .pdf
《2022年软件过程规范推荐 .pdf》由会员分享,可在线阅读,更多相关《2022年软件过程规范推荐 .pdf(10页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、软件过程规范(初本)1.总则最大限度提高Q&P(质量与生产率) ,提高 Q&P 的可预见性,是每一个软件开发机构的最大目标。而Q&P 依赖于三个因素:过程、人和技术,因此要实现Q&P 的提高,除了加强技术能力, 引进、培育更多优质技术人才之外,规范、改进机构的过程是一个十分重要的手段。我们希望通过在制定软件过程规范标准,并在软件开发实践中不断地完善、修订,提高 Q&P 和 Q&P 的可预见性。本组规范采用CMM(软件过程成熟度模型)的指导, 吸收 RUP、XP、MSF、PSP、TSP等过程规范指南的思想、方法及实践, 充分结合 C#技术的实际情况,采用较为先进的技术、方法、 工具,为我组的软件
2、开发工作提供一部详细、可操作的过程指南。在本组规范的第一版本中, 主要包括管理过程和开发过程两个部分,管理过程中包括项目管理过程、需求变更管理过程、配置管理过程。对于软件开发项目中的其它的一些过程将会在实践中不断补充、完善。2.项目管理过程规范项目管理过程主要包括三个阶段:项目立项与计划、项目实施、项目关闭。2.1 项目立项与计划参与人员:本组全体人员;入口准则:接到软件开发立项申请表;出口准则:立项申请人签字确认了经修订正后的正式软件项目计划,并通过工作任务卡下达了开发任务,开发工作正式开始;输入:经审批的软件开发立项申请表、与需求相关的业务资料;输出: 软件项目计划 、 软件需求规格说明书
3、、 开发任务卡 ;活动:1. 接到软件开发立项申请表后,由组长指定前期负责人,并告知立项申请人;2. 前期负责人阅读软件开发立项申请表后,通过与立项申请人的沟通、阅读立项申请人提交的材料、通过立项申请人与客户直接交流等方式,了解项目目标、 范围与基本需求;并形成最初的软件需求规格说明书;3. 前期负责人和全组其他相关人员制定最初的软件项目计划,并组织评审;4. 向立项申请人提交最初的软件项目计划;5. 最初的软件项目计划通过立项申请人的确认后,组长计划安排需求分析;6. 需求分析完成后,形成正式的软件需求说明书,提交立项申请人确认;(需求分析过程参见开发过程规范部分)7. 根据立项申请人确认后
4、的软件需求说明书,组长组织进行软件高层设计,并对工作任务进行分解,并根据实际需要向技术组申请资源,组建项目组队;8. 组长根据工作任务分解,下发工作任务卡,并协同组队成员进行任务估算;注:工作任务包括模块开发任务、其它任务(如安装);模块开发任务主要包括:详细设计、编码和单元测试9. 任务估算完成后,组队成员向组长提交个人进度安排(以甘特图的形式表示),职责根据每个组队成员的个人进度安排修订软件项目计划(必须包括总的计划甘特图) ,并提交立项申请人确认;10. 立项申请人确定后,组长根据软件项目计划基线,补充工作任务卡,下发到每名师资料总结 - - -精品资料欢迎下载 - - - - - -
5、- - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 10 页 - - - - - - - - - 个组队成员,开发工作开始。相关模板:软件需求规格说明书、 软件项目计划 、 工作任务卡说明:如果计划确认、需求确认未通过,立项申请人与组长进行协商,进行修正,无法达成共识的,进行劝阻讨论;2.2 项目实施参与人员:组长及全体组员;入口准则: 项目计划基线已建立,并通过立项申请人确定,带有工作进度要求的工作任务卡已下发到每个项目成员;出口准则:立项申请人在验收报告上签字确认;输入: 软件需求规格说明书、 软件项目计划 、 工作任务卡 ;输出:经验
6、收测试的可交付的程序、源代码及相关文档。活动:1、 在开发期间,项目成员每周需上交一份时间日志、 缺陷日志 ,每天向组长汇报工作任务进度;2、 在开发期间, 组长负责填写 项目进度周报 报于立项申请人 (周报的第一页和“ 跟踪甘特图 ” ) ;3、 组长必须根据实际的进度情况,及时调整项目计划,若发现进度延误,需采取措施。相关模板:软件项目计划 、 开发任务卡 、 时间日志 、 缺陷日志、 项目进度周报2.3 项目关闭参与人员:组长及全体组员;入口准则:立项申请人在验收报告上确认;出口准则:形成项目总结,完成项目绩效考核,项目数据存入“ 过程数据库 ” ;输入: 时间日志 、 缺陷日志 、 项
7、目开发计划 ;输出: 项目总结 、已完成的项目绩效考核表、过程数据库中的该项目记录;活动:1、组长主持召开项目总结会,交流项目实施过程中的心得体会,对项目实施中的成功处、不足处进行总结,并由组长形成项目总结;2、组织对该项目进行绩效考核,并填写相应的项目绩效考核表;3、组长组织所有成员对项目过程中的文档、源程序等资料进行整理、归档;4、 由组长根据过程数据库的需要,整理相应的数据, 提交给相关人员存入过程数据库。相关模板:项目总结 、 项目绩效考核表3.开发过程规范开发过程是提炼用户需求,设计、构建和测试满足这些需求的软件并最终将其交付给客户的过程。 是软件过程中的主体过程之一。当开发新的应用
8、或计划为现有的应用进行重要的增强时,需使用本规范所定义的开发过程执行。项目管理过程是对开发过程进行计划、监控/管理、总结的辅助过程,但由于项目管理是保证进度、 质量的重要手段,因此在软件项目中也是十分重要的过程之一。而需求管理过程与配置管理过程则是次重要的辅助过程,需求管理过程是一个需求变更管理的过程,以对变更进行统一的管理;配置管理过程的最重要工作就是版本控制,使得开发过程中的各种交付物能够有机地形成一个个整体。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 10 页
9、- - - - - - - - - 因此以上四个过程是交织进行的,均是为成功完成软件项目的保障过程。3.1 过程总述现在比较通行的开发过程模型包括:瀑布模型、演化模型、原型模型、螺旋模型等。根据本组的项目特点、队伍规模、 组员情况等实际因素,决定选择快速原型和增量式相结合的模型,并根据本组特点,进行合理的修改,使其成为本组本阶段的软件开发过程。本规范将整个开发过程分为:需求分析、高层设计、详细设计、编码和单元测试、增量编码及测试、集成计划与测试、系统测试验收测试与安装、维护等九个阶段。3.2 需求分析阶段需求分析的主要目的是生成一个正确说明客户所有需求的文档。换言之, 软件需求规格(Softw
10、are Requirement Specification , SRS)文档是该阶段的主要输出。正确的需求分析和确定需求规格对一个项目的成功是非常关键的。许多在系统和验收测试时发现的缺陷是在需求阶段产生的。 在验收阶段去掉需求阶段产生的一个错误将比在需求阶段本身去掉该错误要多花 100 多倍的费用。很明显,在执行这阶段时,正确地生成具有最少缺陷的SRS 是非常必要的。参与人员:组长及全体组员;入口准则:项目立项,最初的项目计划已得到立项申请人的确认。出口准则:立项申请人在软件需求规格说明书上签字确认;输入: 项目立项申请表 、最初的项目计划 ,需求相关的资料;输出:经确认的软件需求规格说明书;
11、活动:整个需求分析过程主要包括以下几个步骤:1、 首先,组长及全体组员一块,做好需求分析的准备,包括阅读相关的背景资料,熟悉客户的实际情况,准备用户访谈计划,准备会谈问题清单等;2、 然后通过面谈、专题讨论会等形式进行沟通,采集需求的详细内容,澄清每一个需求点;从而界定出系统的目标和范围;3、 对所采集和澄清的需求进行分析,构建需求模型,从功能性、非功能性两个方面进行需求分析,深入领会客户需求;4、 形成软件需求规格说明书,建立软件需求基线,并为软件需求评审做好准备;5、 由组长安排软件需求评审,协同立项申请人进行需求评审;6、 立项申请人 或客户 在软件需求规格说明书上确认。相关模板:软件需
12、求规格说明书3.3 系统架构设计阶段高层设计是软件开发过程中的一个重要阶段,在这个阶段将从计算机实现的逻辑角度开发针对用户需求的解决方案。这一解决方案是一个高级的抽象方案。高层设计要设计出各主要部分, 并说明他们在技术上如何工作:1)相互间的协作; 2)所需外在的硬件和软件环境;3)内在环境。也就是说,高层设计确定了组成产品的构件,定义了每个构件的功能任务,并且定义了构件间的接口及构件到运行环境的外部接口。参与人员:组长及全体组员;入口准则:软件需求规格说明书已通过立项申请人的确认;出口准则:形成高层设计,实现任务分解,所有的问题得到解决;输入: 软件需求说明书输出: 高层设计说明书 (功能与
13、数据库设计) 、详细设计、编码、文档和用户接口标名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 10 页 - - - - - - - - - 准;活动:1、 制定详细设计、编码、文档和用户接口的标准;2、 根据项目特点选择运行的目标平台和开发工具;3、 制定软件的体系结构,定义逻辑和物理的对象模型,包括确定类、类的属性、类方法、类之间的关系和对象间的动态交互。若采用结构化设计,则该活动应为功能设计;4、 从需求规格说明书中的数据模型中得到物理数据库结构,进行物理数据库设计
14、:包括确定表 /记录类型、域和其他部分。5、 生成高层设计说明书,并组织设计评审。相关模板:高层设计说明书3.4 详细设计阶段在详细设计阶段,高层设计阶段开发出的整体应用被分成几个模块(或构件)和程序。为每个程序(或构件)进行逻辑设计,然后归档作为程序规格,同时为每个程序(或构件)生成一个单元测试计划。详细设计阶段的重要活动包括通用例程和程序的确定、框架程序的开发以及用于提高生产率的实用程序和工具的开发。在详细设计阶段负责每个程序、模块(或构件)的内部设计,确定其程序流程,并且可以通过使用设计语言、图形流程图(如活动图、状态图)等,或通过简单地写叙述而将设计文档化。参与人员:每个模块(或构件)
15、的任务承担人;入口准则:高层设计说明书已通过评审;出口准则:完成详细设计,所有的问题得到解决,详细设计与单元测试计划文档化;输入: 软件需求规格说明书、 高层设计说明书 、详细设计标准输出: 详细设计说明书 、 单元测试计划活动:1、 将高层设计中的每个程序(或构件)细分成小的组件;2、 对每个小组件进行详细设计,包括确定调用方法、输入和输出、程序逻辑、数据结构等;3、 根据组件的逻辑,制定单元测试计划,包括确定单元测试环境、测试用例、测试数据等;4、 向组长(或高层设计者)提交详细设计与单元测试计划;相关模板:详细设计说明书 、 单元测试计划3.5 编码和单元测试在编码子阶段, 根据详细设计
16、用编程语言编写所需的程序。这个阶段根据合适的编码规范产生源代码、可执行代码以及数据库(如果使用了数据库)。这个阶段的输出是随后测试和验证的主体。 而单元测试子阶段则是根据详细设计阶段所制定出来的单元测试计划进行测试,验证每一个组件正确、可用。参与人员:每个模块(或构件)的任务承担人;入口准则:详细设计说明书已通过批准,编码规范已建立;出口准则:成功执行所有单元测试计划中的测试用例;输入: 软件需求规格说明书、 高层设计说明书 、 详细设计说明书 、 单元测试计划编码、用户接口标准;输出:测试数据、源代码、可执行代码、单元测试报告名师资料总结 - - -精品资料欢迎下载 - - - - - -
17、- - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 10 页 - - - - - - - - - 活动:1、 根据详细设计,按照编码、用户接口规范编写程序;2、 对程序进行代码复查、编译、调试,直到程序运行通过,符合详细设计的要求;3、 根据单元测试计划进行单元测试,生成单元测试报告。相关模板:单元测试报告3.6 增量编码及测试增量移入的主要任务是在原型开发的系统的基础上,增加本组讨论后认为可以并能实现的增量。参与人员:组长及全体组员;入口准则:已检测完毕的原型系统;出口准则:进行增量开发后的系统,以及相关的开发和说明文档;输入: 软件需求
18、说明书 、 高层设计说明书输出:增量测试数据、更新的源代码、可执行代码、单元测试报告3.7 集成计划与测试集成是把设计阶段制定的,已通过单元测试的模块构建成一个完整软件结构的系统方法。可采用很多方式进行集成,集成计划必须指定模块集成的顺序。在该阶段,同时进行测试,以发现与接口相关的缺陷。集成按照集成计划中制定的顺序进行,并执行每个集成阶段的相应测试用例。集成计划描述了集成顺序、额外需要的软件、测试环境和资源需求。集成计划与集成测试计划通常一起完成。参与人员:组长,集成团队;入口准则:经批准的高层设计说明书;出口准则:集成计划和集成测试计划经过评审和授权;输入: 高层设计说明书 、源程序输出:
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年软件过程规范推荐 2022 软件 过程 规范 推荐
限制150内