需求跟踪

article/2025/8/31 0:55:48

需求跟踪概述

需求跟踪需求跟踪是指跟踪一 个需求使用期限的全过程,需求跟踪包括编制每个需求同系统元素之间的联系文档,这些元素包括其他类型的需求,体系结构,其他设计部件,源代码模块,测试, 帮助文件等。需求跟踪为我们提供了由需求到产品实现整个过程范围的明确查阅的能力。需求跟踪的目的是建立与维护“需求-设计-编程-测试”之间的一致性, 确保所有的工作成果符合用户需求。

需求跟踪的方式

需求跟踪有两种方式:

(1)正向跟踪。检查《产品需求规格说明书》中的每个需求是否都能在后继工作成果中找到对应点。

(2)逆向跟踪。检查设计文档、代码、测试用例等工作成果是否都能在《产品需求规格说明书》中找到出处。

正向跟踪和逆向跟踪合称为“双向跟踪”。不论采用何种跟踪方式,都要建立与维护需求跟踪矩阵(即表格)。需求跟踪矩阵保存了需求与后继工作成果的对应关系。

需求跟踪的内容

跟踪能力(联系)链(traceability link)使你能跟踪一个需求使用期限的全过程,即从需求源到实现的前后生存期。跟踪能力是优秀需求规格说明书的一个特征。为了实现可跟踪能力,必须统一地标识出每一个需求,以便能明确地进行查阅。

图1:四类需求可跟踪能力

图1说明了四类需求跟踪能力链。客户需求可向前追溯到需求,这样就能区分出开发过程中或开发结束后由于需求变更受到影响的需求。这也确保了需求规格说明书包括所有客户需求。同样,可以从需求回溯相应的客户需求,确 认每个软件需求的源头。如果用使用实例的形式 来描述客户需求,图的上半部分就是使用实 例和功能性需求之间的跟踪情况。图的下半 部分指出:由于开发过程中系统需求转变为软件 需求、设计、编写等,所以通过定义单个需求和 特定的产品元素之间的(联系)链可从需求向前 追溯。这种联系链使你知道每个需求对应的产品 部件,从而确保产品部件满足每个需求。第四类 联系链是从产品部件回溯到需求,使你知道每个 部件存在的原因。绝大多数项目不包括与用户需 求直接相关的代码,但对于开发者却要知道为什 么写这一行代码。如果不能把设计元素、代码段 或测试回溯到一个需求,你可能有一个“画蛇添 足的程序”。然而,若这些孤立的元素表明了一 个正当的功能,则说明需求规格说明书漏掉了一项需求。

跟 踪能力联系链记录了单个需求之间的父层、互连、依赖的关系。当某个需求变更(被删除或修改)后,这种信息能够确保正确的变更传播,并将相应的任务作出正确 的调整。下图2说明了许多能在项目中定义的直接跟踪能力联系链。一个项目不必拥有所有种类的跟踪能力联系链,要根据具体的情况调整。

需求跟踪目的

在某种程度上,需求跟踪提供了一个表明与合同或说明一致的方法。更进一步,需求跟踪可以改善产品质量,降低维护成本,而且很容易实现重用。

图2:一些可能的需求跟踪能力联系链

需求跟踪是个要求手工操作且劳动强度很大的任务,要求组织提供支持。随着系统开发的进行和维护的执行,要保持关联链信息与实际一致。跟踪能力信息一旦过时,可能再也不会重建它了。由于这些原因,应该正确使用需求跟踪能力。

下面是在项目中使用需求跟踪能力的一些好处:

  • 审核(certification) 跟踪能力信息可以帮助审核确保所有需求被应用。
  • 变更影响分析跟踪能力信息在增、删、改需求时可以确保不忽略每个受到影响的系统元素。
  • 维护可靠的跟踪能力信息使得维护时能正确、完整地实施变更,从而提高生产率。要是一下子不能为整个系统建立跟踪能力信息,一次可以只建立一部分,再逐渐增加。从系统的一部分着手建立,先列表需求,然后记录跟踪能力链,再逐渐拓展。
  • 项目跟踪在开发中,认真记录跟踪能力数据,就可以获得计划功能当前实现状态的记录。还未出现的联系链意味着没有相应的产品部件。
  • 再设计(重新建造) 你可以列出传统系统中将要替换的功能,记录它们在新系统的需求和软件组件中的位置。通过定义跟踪能力信息链提供一种方法收集从一个现成系统的反向工程中所学到的方法。
  • 重复利用跟踪信息可以帮助你在新系统中对相同的功能利用旧系统相关资源。例如:功能设计、相关需求、代码、测试等。
  • 减小风险使部件互连关系文档化可减少由于一名关键成员离开项目带来的风险。
  • 测试测试模块、需求、代码段之间的联系链可以在测试出错时指出最可能有问题的代码段。

以 上所述许多是长期利益,减少了整个产品生存期费用,但同时要注意到由于积累和管理跟踪能力信息增加了开发成本。这个问题应该这样来看,把增加的费用当作一 项投资,这笔投资可以使你发布令人满意同时更容易维护的产品。尽管很难计算,但这笔投资在每一次修改、扩展或代替产品时都会有所体现。如果在开发工程中收 集信息,定义跟踪能力联系链一点也不难,但要在整个系统完成后再实施代价确实很大。

CMMI要求具备需求跟踪能 力。软件产品工程活动的关键过程域有关于它的陈述,“在软件工作产品之间,维护一致性。工作产品包括软件计划,过程描述,分配需求,软件需求,软件设计, 代码,测试计划,以及测试过程。”需求跟踪过程中还定义了一些关于一个组织如何处理需求跟踪能力的期望。

需求跟踪能力矩阵

表 示需求和别的系统元素之间的联系链的最普遍方式是使用需求跟踪能力矩阵。下表展示了这种矩阵,这是一个“化学制品跟踪系统”实例的跟踪能力矩阵的一部分。 这个表说明了每个功能性需求向后连接一个特定的使用实例,向前连接一个或多个设计、代码和测试元素。设计元素可以是模型中的对象,例如数据流图、关系数据 模型中的表单、或对象类。代码参考可以是类中的方法,源代码文件名、过程或函数。加上更多的列项就可以拓展到与其它工作产品的关联,例如在线帮助文档。包 括越多的细节就越花时间,但同时很容易得到相关联的软件元素,在做变更影响分析和维护时就可以节省时间。

表1:一种需求跟踪能力矩阵
用例功能需求量设计元素代码测试实例
UC-28
UC-29
Catalog.query.sort
catalog.query.import
Class
Catalog
Class
catalog
Catalog.sort()
Catalog.import()
Catalog.validate()
Search.7
Search.8
Search.8
Search.13
Search.14

跟踪能力联系链可以定义各种系统元素类型间的一对一,一对多,多对多关系。表1中允许在一个表单元中填入几个元素来实现这些特征。这里是一些可能的分类:

  • 一对一一个代码模块应用一个设计元素。
  • 一对多多个测试实例验证一个功能需求。
  • 多对多每个使用实例导致多个功能性需求,而一些功能性需求常拥有几个使用实例。

手 工创建需求跟踪能力矩阵是一个应该养成的习惯,即使对小项目也很有效。一旦确立使用实例基准,就准备在矩阵中添加每个使用实例演化成的功能性需求。随着软 件设计、构造、测试开发的进展不断更新矩阵。例如,在实现某一功能需求后,你可以更新它在矩阵中的设计和代码单元,将需求状态设置为“已完成”。表示跟踪 能力信息的另一个方法是通过矩阵的集合,矩阵定义了系统元素对间的联系链。例如:

  • 一类需求与另一类需求之间。
  • 同类中不同的需求之间。
  • 一类需求与测试实例之间。

可以使用这些矩阵定义需求间可能的不同联系,例如:指定/被指定、依赖于、衍生为以及限制/被限制。

下表2中说明了两维的跟踪能力矩阵。矩阵中绝大多数的单元是空的。每个单元指示相对应行与列之间的联系,可以使用不同的符号明确表示“追溯到”和“从.. 回溯”或其他联系。表2中使用一个箭头表示一个功能性需求是从一个使用实例追溯来的。这些矩阵相对于表16-6中的单跟踪能力表更容易被机器自动支持。

表2:反映使用实例与功能需求之间联系的需求跟踪能力矩阵
功能
需求
用例
U C - 1U C - 2U C - 3U C - 4
F R - 1   
F R - 2   
F R - 3   
F R - 4   
F R - 5  
F R - 6   

跟踪能力联系链无论谁有合适的信息都可以定义。下表3定义了一些典型的知识源,即关于不同种类源和目标对象间的联系链。定义了可以为工程项目提供每种跟踪能力信息的角色和个人。

表3:跟踪能力联系链可能的信息源
链的源对象种类链的目的对象种类信息源
系统需求
用例
功能性需求
功能性需求
功能性需求
设计元素
功能性需求
软件需求
功能性需求
功能性需求
软件体系结构元素
其他设计元素
代码
测试实例
系统工程师
需求分析员
需求分析员
软件体系结构(设计)者
开发者
开发者
测试工程师

需求跟踪能力工具

由于联系链源于开发组成员的头脑中,所以需求跟踪能力不能完全自动化。然而,一旦已确定联系链,特定工具就能帮你管理巨大的跟踪能力信息。可以使用电子数据表来维护几百个需求的矩阵,但更大的系统需要更“鲁棒”的解决办法。

具 有强大需求跟踪能力的商业需求管理工具均使用如表16 -7的跟踪能力矩阵。可以在工具的数据库中存储需求和其他信息,定义不同对象间的联系链,甚至包括同类需求的对等联系链。有一些工具需要区分“追溯到(跟 踪进)”与“从..回溯(跟踪出)”关系,自动定义相对的联系链。这就是说,如果你指出需求R追溯到测试实例T,工具会自动定义相对的联系“ T从R回溯”。还有一些工具可以在联系链某端变更后将另一端标为“可疑”。可以让你检查确保知道变更的后续效果。

这些工具允许定义“跨项目” 或“跨子系统”的联系链。一个有20个子系统的大项目,某些高层产品需求建立在多个子系统之上。有些情况下,分配给一个子系统的需求,实际上是由另一个子 系统提供的服务完成的。这样的项目采用商业需求管理工具可以成功地跟踪这些复杂的跟踪能力关系。

需求跟踪能力过程

当你应用需求跟踪能力来管理工程时,可以考虑下列步骤:

  • 决定定义哪几种联系链,可以参见图2来进行。
  • 选择使用的跟踪能力矩阵的种类,是表1还是表2。
  • 确定对产品哪部分维护跟踪能力信息。由关键的核心功能、高风险部分或将来维护量大的部分开始做起。
  • 通过修订过程和核对表来提醒开发者在需求完成或变更时更新联系链。
  • 制定标记性的规范,用以统一标识所有的系统元素,达到可以相互联系的目的。若必要,作文字记录,这样就可以分析系统文件,便于重建或更新跟踪能力矩阵。
  • 确定提供每类联系链信息的个人。
  • 培训项目组成员,使其接受需求跟踪能力的概念和了解重要性、这次活动的目的、跟踪能力数据存储位置、定义联系链的技术—例如,使用需求管理工具的特点。确保与会人员明白担负的责任。
  • 一旦有人完成某项任务就要马上更新跟踪能力数据,即要立刻通知相关人员更新需求链上的联系链。
  • 在开发过程中周期性地更新数据,以使跟踪信息与实际相符。要是发现跟踪能力数据没完成或不正确那就说明没有达到效果。

需求跟踪能力的可行性

对 有很多子系统的巨大产品进行跟踪能力管理是一项巨大的工程,但这很必要。并不是所有的公司都会因为软件问题而造成严重的结果,然而应该严肃地对待需求跟 踪,尤其对涉及你业务核心的信息系统。考虑了应用技术的成本和不使用的风险后,才能决定是否使用任何改进的需求工程实践。随着软件的发展,要把时间投向回 报丰厚的地方。


http://chatgpt.dhexx.cn/article/kyI2qnRT.shtml

相关文章

怎样修改一篇简历 简历怎么写

一、简历的格式 简历一般分为纸质简历和电子简历。要根据用人单位的要求。如果你在招聘市场进行应聘的话,一般使用纸质简历。而当你在网上投递简历时,则使用电子版。 二、简历的主要内容 简历主要包括个人情况(包括专长)&#xff…

个人简历英语及计算机能力怎么写,简历个人能力怎么写(简历中个人能力的填写技巧)...

我们在网上填写简历的时候总是会有个人能力、计算机水平、英语水平这样比较自主介绍推销自己的填写项目。对于能力介绍如果填写的好可以体现个人的实力与能力,给查看简历的用人单位留下一个好印象,进而获得当面交流的机会,然现实中不重视或随…

9年技术面试官讲解:计算机专业应届生怎样写简历

本人作为面试官,也有过校招经历。在这过程中,发现有些毕业生同学的简历无法证明自己能胜任程序员的工作,甚至也没有面试价值。同时,本人也见识了不少“一看就想留下”的简历。在本文里,就将用正反两方面的实例&#xf…

计算机方面毕业生怎样写简历

本人曾经作为面试官,也有过校招经历。在这过程中,发现有些毕业生同学的简历无法证明自己能胜任程序员的工作,甚至也没有面试价值。同时,本人也见识了不少“一看就想留下”的简历。在本文里,就将用正反两方面的实例&…

【第四章】输入、输出接口P0~P3

文章目录 【 1. 接口电路 】【 2. P0口 】【 3. P1口 】【 4. P2口 】【 5. P3口 】【 6. 小结 】 【 1. 接口电路 】 接 口 电 路 的 必 要 性 : \color{red}{接口电路的必要性:} 接口电路的必要性:  计算机对外设进行数据操作时&#xff0…

统计学P值

P 值是最常用的一个统计学指标,几乎统计软件输出结果都有P值。 统计学的观点,超过一定基准(比如 5%,其实是低于5%),就不能简单地认为这是偶然事件了,而是受到了外在的影响。 数学大佬出来定义了…

c3p0详细配置(c3p0-config.xml)及使用

参数详细说明请跳转&#xff1a; 数据库连接池c3p0常用配置说明 <c3p0-config> <default-config> <!-- 数据库驱动名 --> <property name"driverClass" ></properties> <!-- 数据库的url --> &…

3.FXBLUE跟单原理

3.1 FXBLUE跟单速度 fxblue喊单EA一旦发现其MT4账户中有新的订单&#xff0c;就会向fxblue跟单EA发送一条消息。然后&#xff0c;fxblue跟单EA将尝试进行相同的交易&#xff0c;也就是实时跟单&#xff0c;复制订单。这个过程是快速立即马上响应&#xff0c;但复制交易所需的时…

介绍几种电路上常用的塑料插接件(1)

介绍几种电路上常用的插接件&#xff08;1&#xff09; 最近在做几个电路方面的小项目。做这做这发现有好多小零件都不知道叫什么。比如上面用到的大大小小的插接件。都经常见&#xff0c;但是就是不知道名字。所以就专门花了点时间调研了一番。 这篇博客就来总结几种常见的塑…

t460p加固态硬盘 thinkpad_不仅是硬件升级!ThinkPad T460p评测

原标题:不仅是硬件升级!ThinkPad T460p评测 ThinkPad旗下的T4x0p系列产品一直是追求性能的小黑粉丝们非常关注的一款产品,ThinkPad今年正式推出了最新的T460p商务笔记本,由于T450p的缺席,大家对这款机器有着非常高的期待值。今天的评测将带您了解升级了Skylake处理器的它具…

oracle存储过程动态sql单引号拼接和变量拼接

1.单引号的作用 在oracle中单引号主要有两个作用: 一是字符串都用单引号引用,例如abc;二是转义符,转义符在使用时一般会出现多个连在一起的单引号,相对难理解一些。下面举例说明。 实例1:select from dual; 实例1结果: 实例2:select oracle from dual; 实例2结果: 实…

51单片机并行接口P0~P3

文章目录 前言一、并行接口P0&#xff08;1&#xff09;P0口(2)、P0口作为通用I/O口 二、并行接口P1三、并行接口P2四、并行接口P3P3口的第二特殊功能引脚分配&#xff1a; 归纳四个并行口使用的注意事项如下&#xff1a; 前言 学习51单片机&#xff0c;IO口可以说是重中之重&…

FPGA接口-PMOD,FMC与SYZYGY

现代FPGA 功能强大&#xff0c;它通过芯片的可编程引脚与外围电路相连。比如AD/DA,数字IO以及以太网&#xff0c;USB&#xff0c;CAN &#xff0c;视频I/O 等接口电路。人们将这些接口称为夹层模块&#xff08;Mezzanine Module&#xff09;。为了实现FPGA 系统的模块化设计&am…

校园接单网站源码/跑腿网源码

介绍&#xff1a; 项目功能&#xff1a; 1.校园服务&#xff1a;打印、快递代取、校园跑腿、上门维修、代替服务 等等可自定义 2.添加校园代理 3.提现 4.接单 5.申请接单 6.数据分析 7.广告管理 8.用户管理 实现技术&#xff1a; 1.后台服务端&#xff1a;nodejskoa2mysql 2.后…

程序员接单当渠道

接单之前&#xff0c;先简单说一下接私活的几种项目类型&#xff0c;之后直接上渠道&#xff0c;你可以对照着去找项目~程序员兼职主要分为三种&#xff1a;项目外协、项目整包和自由职业者驻场。所谓的项目外协&#xff0c;指的是需求方这边有自有工程师配合&#xff0c;只需要…

网络安全知识之什么是网络安全?

网络安全的概念&#xff0c;有很多不同的定义。在一些场合中&#xff0c;我们最多的考虑的还是网络的技术安全&#xff0c;但是技术延伸出来的安全又会涉及到社会安全、文化安全、国家安全等等。 网络安全的概念&#xff0c;有很多不同的定义。在一些场合中&#xff0c;我们最多…

计算机网络安全技术复习知识点总结

文章目录 1.网络安全的概念网络安全的定义网络安全的属性网络攻击主动攻击被动攻击 2.网络协议基础协议层次协议分析ARP协议SMTP协议POP3协议HTTP协议 3.消息鉴别与身份认证消息鉴别协议身份认证方式Kerberos认证系统PKI技术PKI提供的服务PKI的主要组件 数字证书 4.密码学在网络…

计算机网络安全基础知识(超详细)

目录 一、http与https的区别 二、HTTP响应码 三、渗透测试和WEB安全漏洞的区别&#xff1f; 四、网络连接的核心-IP地址和端口 五、HTTP超文本传输协议 一、http与https的区别 1、HTTPS 协议需要到 CA &#xff08;Certificate Authority&#xff0c;证书颁发机构&#x…

网络安全重点知识

单选&#xff08;抽20个&#xff09;、判断&#xff08;抽5个&#xff09; 第二章&#xff1a; 第三章&#xff1a; 第四章&#xff1a; 第五章&#xff1a; 第六章&#xff1a; 第八章&#xff1a; 填空&#xff08;抽3个&#xff09; 1、网络安全&#xff1a; 是在网络各个…

三级计算机信息安全基础知识

三级信息安全我过了呜呜呜呜,虽然只是良好,但终于有胆子发当时做的笔记了QVQVQ 目录 历史基础概念访问控制实现方法访问控制依赖原则访问控制类型分布式访问控制&#xff08;Distributed access control&#xff09;自主访问控制模型(Discretionary Access Control)强制访问控…