软件需求分析格式如何写需求分析报告软件需求说明书1.1编写目的:阐明编写需求说明书的目的,指明读者对象1.2项目背景:应包括•项目的委托单位、开心单位和主管部门;•该软件系统与其他系统的关系。
1.3 定义:列出文档中所用到的专门术语的定义和缩写词的愿文。
1.4参考资料:可包括•项目经核准的计划任务书、合同或上级机关的批文•文档所引用的资料、规范等•列出这些资料的作者、标题、编号、发表日期、出版单位或资料来源2任务概述2.1目标2.2运行环境2.3条件与限制3数据描述3.1表态数据3.2动态数据:包括输入数据和输出数据。
3.3数据库描述:给出使用数据库的名称和类型。
3.4数据词典3.5数据采集4功能需求4.1功能划分4.2功能描述5性能需求5.1数据精确度5.2时间特性:如响应时间、更新处理时间、数据转换与传输时间、运行时间等。
5.3适应性:在操作方式、运行环境、与其他软件的接口以及开发计划等发生变化时,应具有的适应能力。
6运行需求6.1用户界面:如屏幕格式、报表格式、菜单格式、输入输出时间等。
6.2硬件接口6.3软件接口6.4故障处理7其他需求如可使用性、安全保密、可维护性、可移植性等。
需求分析的格式需求分析要对目标系统提出完整的、准确的、清晰的和具体的要求。
1.综合需求:项目说明备注1)功能要求描述软件用来做什么能够进行度量衡的相互转换,如:长度公制之间的转换,公制和英制的转换等。
能够添加或创建新的度量衡。
能够按照用户自己的需要进行排序。
能够作为其他软件的插件或辅助工具使用。
能够知道度量衡所应用的范围,如:国家,行业等。
2)性能要求软件能达到什么性能数据的最大存储量,数据的转换要有连续性,软件对每项操作的响应时间,更新处理时间,数据转换和传送时间,软件的输入输出数据精度,软件失败和成功的定义。
3)运行要求软件能正常运行在微软中文版WINDOW系列的可以独立运行的安装包或可执行文件开发软件的开发工具清单。
是否需要外部存储器和数据通信接口。
4)升级要求是否可以升级,是否可以进行扩充。
是否容易进行维护。
能够作为什么软件的插件或辅助工具使用。
如何添加新的公5)对应关系用户需求和软件功能的对应关系说明每一个模块对应实现什么功能。
2.数据要求:项目说明备注1)数据输入来源、准确性、取值范围、格式、非法值的处理、出错信息2)数据输出目的地、准确性、数值范围、格式、非法值的处理、出错信输出的数据可以修改,女口:1米=100厘米=1000毫米,将100 厘米改为90厘米时,相应的1米就自动改为0.9米,1000 毫米变为900毫米。
3)数据存储最大存储量4)数据的安全性访问的权限5)数据备份能否导入和导出可以将输出的数据保存为文本格式6)数据流图在分析过程中得出的数据流图7)数据筛选能够将选择的几个度量单位进行汇总8)主要算法简要描述软件的主要算法3.界面要求:请参照“界面样式图”项目说明备注1)软件名称为软件起一个名字可以发挥自己的想象力2)功能模块有几个功能模块,分别是什么3)颜色采用什么底色,窗口是什么颜色4)字体字型、大小,字间距,颜色5)按钮颜色、字型、大小、样式4.软件描述:从用户的角度来描述软件,相当于一份初步的用户手册。
项目说明备注1)功能描述能实现,不能实现什么需求应用范围。
什么人员可以使用2)性能描述最低配置,操作系统,需要安装什么辅助软件3)操作步骤如何使用软件主要步骤和方法4)用户责任用户在操作过程中的注意事项出现问题时如何解决如何写需求分析报告近来学校的一些科研项目又在申报了,一些学弟开始Q我些软件工程上书面的问题。
大概的总结了下,写到这里。
本文涉及到的是需求分析部分的书写,主要是根据国家标准文档中的要求来的。
在互联网公司或者一些敏捷开发的公司里,其实大家都是秉承着重开发,重讨论,而轻文档的态度。
这个轻文档并不是指没有文档或者几乎不做文档,而是在严格的文档流程中解脱出来,只把最最实际的部分写出来。
这个特征是有互联网本身迭代周期短,版本发布快等特点决定的。
而在实际的兼职项目的时候,同学们就要注意了,最重要的应该就是在签合同的时候一定要附上最清楚的一份需求分析,虽然这份需求说明可能不是按照某些标准文档而来的,描述清楚每个功能达到的效果,而这个效果一定要让客户点头确认,而不能出现“应该是”、“可能是”、“也许是”这样的模糊回答否则在项目后期就会比较难过了。
在学校申请的项目和大型公司项目开发中,是重视文档流程的,一部一部来。
所以还是看情况来对待文档的深度和标准。
、目录:目录要用word的“引用”一>”目录”,自动生成目录,一般都是要三级目录。
通常这部分基本都不需要改结构,直接更新页码即可。
、内容部分。
国家标准软件需求说明书G856T-88下载1引言1.1编写目的说明编写这份软件需求说明书的目的,指出预期的读者。
(这部分说明需求分析报告的概况,例如:本X需求分析报告是为S系统而编写的。
+S系统的两句话概述。
+本X报告旨在使U1 (需求者)明确S系统的要求和细节,给U2(开发人员)了解需求实现的难度和困难,最终提供给U3(审核人、管理者)讨论和审核,达到沟通效果)1.2背景说明:a.待开发的软件系统的名称;b.本项目的任务提出者、开发者、用户及实现该软件的计算中心或计算机网络;c.该软件系统同其他系统或其他机构的基本的相互来往关系。
(这部分可以将a,b,c分为2部分,例子如下:1.2.1项目既况本需求分析报告所预期开发的软件系统是:S。
S是(不是则无)SS系统的某个功能子模块,S和S1、S2等系统之间的联系,以及概述其他系统的状态等等。
122任务分配a.任务提出者:XXXb.软件开发者:XXc.产品使用者:XXd.文档编与者:XXe.预期产品使用者:XX1.3定义 列出本文件中用到的专门术语的定义和外文首字母组词的 原词组。
(这部分很简单,就是描述专业词汇,比如1. XML(Extensible Mark up Language) 即可扩展标记语言, 它与 HTML 一样,都是 SGML(Standard Generalized MarkupLanguage,标准通用标记语言)。
2. Word2,解释。
1.4参考资料列出用得着的参考资料,如:本项目的经核准的计划任务书或合同、上级机关的批文;本文件中各处引用的文件、资料、包括所要用到的软件期和出版单位,说明能够得到这些文件资料的来源。
2任务概述2.1目标 叙述该项软件开发的意图、应用目标、作用范围以及其他应向读者说明的有关该软件开发的背景材料。
解释被开发软件 与其他有关软件之间的关系。
如果本软件产品是一项独立的 软件,而且全部内容自含,则说明这一点。
如果所定义的产 品是一个更大的系统的一个组成部分,则应说明a . b .属于本项目的其他已发表的文件;开发标准。
列出这些文件资料的标题、文件编号、发表日本产品与该系统中其他各组成部分之间的关系,为此可使用一张方框图来说明该系统的组成和本产品同其他各部分的联系和接口。
本模块开发主要是为SS的整体服务,完成SS工作中的XX部分以及相关的工作。
其涉及的范围就是,从下达 A B命令后,到给出C结果的过程。
具体描述:B1,来完成B11功能;B2,来完成B22功能;等等。
本部分是(否)耦合在分词工具包其他部分中的,主要为嵌入方式和先后方式相互交互。
图1.该系统的组成同其他各部分的联系和接口2.2用户的特点列出本软件的最终用户的特点,充分说明操作人员、维护人员的教育水平和技术专长,以及本软件的预期使甩频度。
这些是软件设计工作的重要约束(例如:二次开发和系统调用人员:具有很高的专业知识水平,理解XX的运行机制。
可以对开放代码进行阅读和分析,以完成其系统独特的需求,提供给这部分用户开放API手册和Debug版本的源代码即可;预期这部分用户会占本系统总用户量的多大部分。
XX使用者:具有一定的计算机操作能力和知识,了解XX领域的相关概念和用途。
提供给这部分用户操作手册即可。
预期这部分使用者主要是来简单的XX操作。
维护人员:具有较高的计算机专业水平,可以对常见的系统Bug进行追踪和分析,具有一定的测试能力。
这部分用户主要是采用了本系统之后的后期工作维护者。
等等2.3假定和约束列出进行本软件开发工作的假定和约束,例如经费限制、开发期限等。
(这部分重要是对你有的技术力量、资金状况、人力资源等情况的假设,以使得你可以在什么样的情况和时间范围内完成工作。
工期约束,经费约束,人员约束,地理约束,设备约束等几个方面列举说明。
)3需求规定3.1对功能的规定用列表的方式(例如IPO表即输入、处理、输出表的形式)逐项定量和定性地叙述对软件所提出的功能要求,说明输入什么量、经怎样的处理、得到什么输出,说明软件应支持的终端数和应支持的并行操作的用户数。
(例如:INPUT输入PROCES处理OUTPUT!出LOAD负载量预处理,做怎样的动作,AACCBBBBBbCCCC cc表一、XX模块IPO表对IPO表的简单文字描述。
3.2对性能的规定321精度说明对该软件的输入、输出数据精度的要求,可能包括传输(例如:Xx目标处理:1Byt - 10M,包括左右边界值。
yy 精度范围:….ZZ 的精度:由于XX 的特殊性,本系统均采用XX 型来进行字符统计运算,概率部分以及其他比率部分精度精确到 0.0X%。
322时间特性要求说明对于该软件的时间特性要求,如对:数据的转换和传送时间;(这部分只要一一列举就可以:其具体时间特性要求,如下:a . 响应时间;b . 更新处理时间;d . 解题时间;等的要求。
由于XXX 过程中,需要大量 XXXX操作或怎样,故XX 解题时 间占总时间的最大部分。
其次就是XX 转换和存储的开销。
a . XX b . yy c . ZZ 响应时间:xxms 左右;数据的转换和传送时间: ZZ ; 更新处理时间:yy ;XXX ,等等323灵活性 说明对该软件的灵活性的要求,即当需求发生某些变化时,该软件对这些变化的适应能力,如:同其他软件的接口的变化;对于为了提供这些灵活性而进行的专门设计的部分应该加 以标明。
(这部分按列举来即可, 由于本模块第一目的是用于 其次则是XXXX 。
故本模块的灵活性在于实际应用者的不同。
当需求发生某些变化时,该软件对这些变化的适应能力。
具 体情况如下:d . vv 解题时间: vv 。
a . 操作方式上的变化;b . 运行环境的变化;d . 精度和有效时限的变化;e . 计划的变化或改进。
操作方式上的变化:采用集成运行制和独立运行制两种模式,集成运行制是把本模块嵌入到分词工具包的主框架中,提供给用户具有一定UI的可操作软件;独立运行制是可以独立运行于后台,并提供给各种程序调用的模式的工作方式,以增强其生命力。