软件工程各阶段应该产生哪些文档?

kuaidi.ping-jia.net  作者:佚名   更新日期:2024-08-01
软件开发中会产生哪些文档(所有阶段的文档)?

各个公司不同地,你先把你们公司软件开发阶段列一下,文档自然来。

1问题定义

  问题定义阶段必须回答的关键问题:“要解决的问题是什么?”如果不知道问题是什么就试图解决这个问题,显然是盲目的,只会白白浪费时间和金钱,最终得出的结果很可能是毫无意义的。尽管确切地定义问题的必要性是十分明显的,但是在实践中它却可能是最容易被忽视的一个步骤。

  通过问题定义阶段的工作,系统分析员应该提出关于问题性质、工程目标和规模的书面报告。通过对系统的实际用户和使用部门负责人的访问调查,分析员扼要地写出他对问题的理解,并在用户和使用部门负责人的会议上认真讨论这份书面报告,澄清含糊不精的地方,改正理解不正确的地方,最后得出一份双方都满意的文档。

  问题定义阶段是软件生存周期中最简短的阶段,一般只需要一天甚至更少的时间。

2可行性研究

  这个阶段要回答的关键问题:“对于上一个阶段所确定的问题有行得通的解决办法吗?”为了回答这个问题,系统分析员需要进行一次大大压缩和简化了的系统分析和设计的过程,也就是在较抽象的高层次上进行的分析和设计的过程。

  可行性研究应该比较简短,这个阶段的任务不是具体解决问题,而是研究问题的范围,探索这个问题是否值得去解,是否有可行的解决办法。

  在问题定义阶段提出的对工程目标和规模的报告通常比较含糊。可行性研究阶段应该导出系统的高层逻辑模型(通常用数据流图表示),并且在此基础上更准确、更具体地确定工程规模和目标。然后分析员更准确地估计系统的成本和效益,对建议的系统进行仔细的成本/效益分析是这个阶段的主要任务之一。

  可行性研究的结果是使用部门负责人做出是否继续进行这项工程的决定的重要依据,一般说来,只有投资可能取得较大效益的那些工程项目才值得继续进行下去。可行性研究以后的那些阶段将需要投入要多的人力物力。及时中止不值得投资的工程项目,可以避免更大的浪费。

3需求分析

  这个阶段的任务仍然不是具体地解决问题,而是准确地确定“为了解决这个问题,目标系统必须做什么”,主要是确定目标系统必须具备哪些功能。

  用户了解他们所面对的问题,知道必须做什么,但是通常不能完整准确地表达出他们的要求,更不知道怎样利用计算机解决他们的问题;软件开发人员知道怎样使用软件实现人们的要求,但是对特定用户的具体要求并不完全清楚。因此系统分析员在需求分析阶段必须和用户密切配合,充分交流信息,以得出经过用户确认的系统逻辑模型。通常用数据流图、数据字典和简要的算法描述表示系统的逻辑模型。

  在需求分析阶段确定的系统逻辑模型是以后设计和实现目标系统的基础,因此必须准确完整地体现用户的要求。系统分析员通常都是计算机软件专家,技术专家一般都喜欢很快着手进行具体设计,然而,一旦分析员开始谈论程序设计的细节,就会脱离用户,使他们不能继续提出他们的要求和建议。较件工程使用的结构分析设计的方法为每个阶段都规定了特定的结束标准,需求分析阶段必须提供完整准确的系统逻辑模型,经过用户确认之后才能进入下一个阶段,这就可以有效地防止和克服急于着手进行具体设计的倾向。

4总体设计

  这个阶段必须回答的关键问题是:“概括地说,应该如何解决这个问题?”

  首先,应该考虑几种可能的解决方案。列如,目标系统的一些主要功能是用计算机自动完成还是用人工完成;如果使用计算机,那么是使用批处理方式还是人机交互方式;信息存储使用传统的文件系统还是数据库……。通常至少应该考虑下述几类可能的方案:

  低成本的解决方案。系统只能完成最必要的工作,不能多做一点额处的工作。

  中等成本的解决方案。这样的系统不仅能够很好地完成预定的任务,使用起来很方便,而且可能还具有用户没有具体指定的某些功能和特点。虽然用户没有提出这些具体要求,但是系统分析员根据自己的知识和经验断定,这些附加的能力在实践中将证明是很有价值的。

  高成本的“十全十美”的系统。这样的系统具有用户可能希望有的所有功能和特点。

  系统分析员应该使用系统流程图或其他工具描述每种可能的系统,估计每种方案的成本和效益,还应该在充分权衡各种方案的利弊的基础上,推荐一个较好的系统 (最佳方案),并且制定实现所推荐的系统的详细计划。如果用户接受分析员推荐的系统,则可以着手完成本阶段的另一项主要工作。

  上面的工作确定了解决问题的策略以及目标系统需要哪些程序,但是,怎样设计这些程序呢?结构设计的一条基本原理就是程序应该模块化,也就是一个大程序应该由许多规模适中的模块按合理的层次结构组织而成。总体设计阶段的第二项主要任务就是设计软件的结构,也就是确定程序由哪些模块组成以及模块间的关系。通常用层次图或结构图描绘软件的结构。

5详细设计

  总体设计阶段以比较抽象概括的方式提出了解决问题的办法。详细设计阶段的任务就是把解法具体化,也就是回答下面这个关键问题:“应该怎样具体地实现这个系统呢?”

  这个阶段的任务还不是编写程序,而是设计出程序的详细规格说明。这种规格说明的作用很类似于其他工程领域中工程师经常使用的工程蓝图,它们应该包含必要的细节,程序员可以根据它们写出实际的程序代码。

6编码和单元测试

  这个阶段的关键任务是写出正确的容易理解、容易维护的程序模块。

  程序员应该根据目标系统的性质和实际环境,选取一种适当的高级程序设计语言(必要时用汇编语言),把说细设计的结果翻译成用选定的语言书写的程序,并且仔细测试编写出的每一个模块。

7综合测试

  这个阶段的关键任务是通过各种类型的测试(及相应的调试)使软件达到预定的要求。

  最基本的测试是集成测试和验收测试。所谓集成测试是根据设计的软件结构,把经过单元测试检验的模块按某种选定的策略装配起来,在装配过程中对程序进行必要的测试。所谓验收测试则是按照规格说明书的规定(通常在需求分析阶段确定),由用户(或在用户积极参加下)对目标系统进行验收。

  必要时还可以再通过现场测试或平行运行等方法对目标系统进一步测试检验。

  为了使用户能够积极参加验收测试,并且在系统投入生产性运行以后能够正确有效地使用这个系统,通常需要以正式的或非正式的方式对用户进行培训。

  通过对软件测试结果的分析可以预测软件的可靠性;反之,根据对软件可靠性的要求也可以决定测试和调试过程什么时候可以结束。

  应该用正式的文档资料把测试计划、详细测试方案以及实际测试结果保存下来,做为软件配置的一个组成成分。

8软件维护

  维护阶段的关键任务是,通过各种必要的维护活动使系统持久地满足用户的需要。

  通常有四类维护活动:改正性维护,也就是诊断和改正在使用过程中发现的软件错误;适应性维护,即修改软件以适应环境的变化;完善性维护,即根据用户的要求改进或扩充软件使它更完善;预防性维护,即修改软件为将来的维护活动预先做准备。

  虽然没有把维护阶段进一步划分成更小的阶段,但是实际上每一项维护活动都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开发的全过程。

  都应该经过提出维护要求(或报告问题),分析维护要求,提出维护要求,提出维护方案,审批维护方案,确定维护计划,修改软件设计,修改程序,测试程序,复查验收等一系列步骤,因此实质上是经历了一次压缩和简化了的软件定义和开发的全过程。

分析阶段,一般有开发计划、软件需求规格说明书、数据需求规格说明书。

设计阶段,一般有测试计划,概要设计说明,详细设计说明。
实施阶段,一般有用户手册、操作手册、进度报告、测试报告、开发总结报告。

问题定义:关于规模和目标的报告书
可行性研究阶段:可行性研究报告、项目开发计划
需求分析阶段:项目开发计划(修正)、需求规格说明书、数据要求说明书、测试计划(确认测试)、初步用户手册
总体设计阶段:用户手册(完善)、总体设计说明书、数据库设计说明书、组装测试的测试计划
详细设计阶段:详细设计说明书
编码阶段:开发进度月报
测试阶段:测试分析报告
维护阶段:软件问题报告
可能不全面,常见的应该是这些,欢迎其他人补充。

  • ( )是需求分析阶段完成的文档。
    答:【答案】:B 需求分析阶段成果 在制定开发计划时应兼顾用户给定的要进度和经费要求,又要注意按照软件工程规定的程序和技术要求进行开发工作。软件需求规格说明应满足需求分析的完整性要求,并保证软件需求规格说明应满足需求说明中的所有功能,性能需求均是可实现的。阶段成果有:(1)项目开发计划:(2)...
  • 软件工程文档都包括哪些?
    答:软件工程B(魏振钢).doc免费下载 链接:https://pan.baidu.com/s/1W798Rasdekg6tLpzATBYyA 提取码:1c4v 软件工程是一门研究用工程化方法构建和维护有效、实用和高质量的软件的学科。它涉及程序设计语言、数据库、软件开发工具、系统平台、标准、设计件有电子邮件、嵌入式系统、人机界面、办公套件、...
  • 软件工程有哪些主要阶段?每个阶段的主要工作是什么
    答:F1第一阶段软件工程,免费下载 链接:https://pan.baidu.com/s/1NMX-eXOtRYFpfcsaYpv3Vw 提取码:paem 计划阶段---开发阶段---维护阶段 计划阶段:问题定义,可行性研究,需求分析 开发阶段:概要设计,详细设计,编码,测试 维护阶段:运行与维护 ...
  • 软件工程有哪些主要阶段?每个阶段的主要工作是什么?
    答:如果不知道问题是什么就试图解决这个问题,显然是盲目的,只会白白浪费时间和金钱,最终得出的结果很可能是毫无意义的。尽管确切地定义问题的必要性是十分明显的,但是在实践中它却可能是最容易被忽视的一个步骤。\x0d\x0a\x0d\x0a 通过问题定义阶段的工作,系统分析员应该提出关于问题性质、工程目标和规模的书面...
  • 软件开发的流程都有哪些步骤呢?
    答:完成测试后,完成验收并完成最后的一些帮助文档,整体项目才算告一段落,当然日后少不了升级,修补等等工作,只要不是想通过一锤子买卖骗钱,就要不停的跟踪软件的运营 状况并持续修补升级,直到这个软件被彻底淘汰为止。什么是软件开发的核心问题 按照软件工程鼻祖,《人月神话》作者 Brooks 在“没有银弹—...
  • 软件生存周期都包括哪些活动
    答:软件生存周期是软件的产生直到报废的生命周期,周期内有问题定义、可行性分析、总体描述、系统设计、编码、调试和测试、验收与运行、维护升级到废弃等阶段。这种按时间分程的思想方法是软件工程中的一种思想原则,即按部就班、逐步推进,每个阶段都要有定义、工作、审查、形成文档以供交流或备查。
  • 软件开发各阶段的输入和输出分别是什么?
    答:测试 输入输出 应该是一些测试用例 和 软件输入结果 维护??? 我也不晓得 面向对象 输入 需求分析 输出 用例图 多次迭代 产生出一个一个的类 不知道是不是你问的东西 你的问法好奇怪 呵呵 详见 软件工程导论 张什么潘 写的不错 很详细 ...
  • 软件开发文档的用途有哪些(软件工程文档的作用)
    答:3.系统架构:说明软件系统的整体结构、组件和模块之间的关系,有助于开发人员理解系统的设计和实现。4.编码标准和规范:定义团队在编写代码时应遵循的标准和规范,以确保代码的一致性、可读性和可维护性。5.API文档:提供应用程序编程接口(API)的详细说明,帮助开发人员正确使用和集成系统的功能。6.测试...
  • 什么是软件工程?包括哪些内容?
    答:正确性指软件产品达到预期功能的程度。可用性指软件基本结构、实现及文档为用户可用的程度。开销合宜是指软件开发、运行的整个开销满足用户要求的程度。这些目标的实现不论在理论上还是在实践中均存在很多待解决的问题,它们形成了对过程、过程模型及工程方法选取的约束。(2)软件工程过程:生产一个最终能满足...
  • 软件工程中,软件的生命周期内定义了哪些主要的阶段或活动
    答:你好!周期内有问题定义、可行性分析、总体描述、系统设计、编码、调试和测试、验收与运行、维护升级到废弃等阶段,这种按时间分程的思想方法是软件工程中的一种思想原则,即按部就班、逐步推进,每个阶段都要有定义、工作、审查、形成文档以供交流或备查,以提高软件的质量。